2012-06-29 17 views
1

我从wordpress部分交叉发布这个,b/c我认为问题更多的是因为我对OOP缺乏理解,所以也许它应该在这里发布第一个地方。wordpress插件中的一个类的多个实例

在编写wordpress插件时,我想创建一个我可以在每个插件中使用的类来处理插件选项页面的普通创建:所以添加菜单页面,白名单设置,吐出和验证选项等我基本上想过,我想重新使用一些我必须写的课程。

在最基础的位置,我期待着我可以在插件1和插件2(带有不同的$参数)中说新的KIA_Plugin_Options($ args),并且每个插件都可以找出各自插件的选项页面。然而,我已经在2个插件中添加了下面的类,而不是为每个插件创建菜单,它只处理1,然后死亡。所以它的一部分工作,但并不是我可以重复使用的万能药,所以我觉得我错过了OOP中的一些重要概念。

这里是我的选择类的骨架:

<?php 

class KIA_Plugin_Options { 

    private $page_title; 
    private $menu_title; 
    private $capability; 
    private $menu_slug; 
    private $setting_name; 
    private $option_name; 

    function KIA_Plugin_Options($args){ 

    //convert $args to array 
    if(!is_array($args)) $args['page_title'] = $args; 

    if(!isset($args['page_title'])) die (__('Plugin Options needs at least the plugin\'s page title parameter.','kia_plugin_options')); 

    // Define the class variables 
    $this->page_title = $args['page_title']; 
    $this->menu_title = isset($args['menu_title']) ? $args['menu_title'] : $this->page_title; 
    $this->capability = isset($args['capability']) ? $args['capability'] : 'manage_options'; 
    $this->menu_slug = isset($args['menu_slug']) ? $args['menu_slug'] : sanitize_title_with_dashes($this->menu_title); 
    $this->setting_name = isset($args['setting_name']) ? $args['setting_name'] : $this->menu_slug; 
    $this->option_name = isset($args['option_name']) ? $args['option_name'] : $this->menu_slug; 

    // Set-up Action and Filter Hooks 
    register_activation_hook(__FILE__, array(&$this,'add_defaults_options')); 
    register_uninstall_hook(__FILE__, array(&$this,'delete_plugin_options')); 

    //add settings page 
    add_action('admin_init', array(&$this,'register_settings')); 
    add_action('admin_menu', array(&$this,'add_options_page')); 

    //add settings link to plugins page 
    add_filter('plugin_action_links', array(&$this,'add_action_links'), 10, 2); 
    } 


    // ------------------------------------------------------------------------------ 
    // CALLBACK FUNCTION FOR: register_activation_hook(__FILE__, 'add_defaults_options') 
    // ------------------------------------------------------------------------------ 

    // Define default option settings 
    function add_defaults_options() { 
    if(get_option('kia_tell_a_friend_options')) return false; 

    $defaults = array( 
       "emailsubject" => __('I saw this and thought of you!', 'kia_tell_a_friend'), 
       "emailmsg" => __('I just saw this!', 'kia_tell_a_friend'), 
       "twittermsg" => __('Check this out!', 'kia_tell_a_friend') 
    ); 
    update_option('kia_tell_a_friend_options', $defaults); 
    } 


    // -------------------------------------------------------------------------------------- 
    // CALLBACK FUNCTION FOR: register_uninstall_hook(__FILE__, 'delete_plugin_options') 
    // -------------------------------------------------------------------------------------- 

    // Delete options table entries ONLY when plugin deactivated AND deleted 
    function delete_plugin_options() { 
    $options = get_option('kia_tell_a_friend_options', true); 
    if(isset($options['delete'])) delete_option('kia_tell_a_friend_options'); 
    } 


    // ------------------------------------------------------------------------------ 
    // CALLBACK FUNCTION FOR: add_action('admin_init', array(&$this,'register_settings')); 
    // ------------------------------------------------------------------------------ 

    // Init plugin options to white list our options 
    function register_settings(){ 
    register_setting($this->setting_name, $this->option_name, array(&$this,'validate_options')); 
    } 

    // ------------------------------------------------------------------------------ 
    // CALLBACK FUNCTION FOR: add_action('admin_menu', array(&$this,'add_options_page')); 
    // ------------------------------------------------------------------------------ 

    // Add menu page 
    function add_options_page() { 
    $page = add_options_page($this->page_title , $this->menu_title, $this->capability, $this->menu_slug, array(&$this,'render_form')); 

    /* Using registered $page handle to hook stylesheet loading */ 
    add_action('admin_print_styles-' . $page, array(&$this,'admin_style')); 
    } 

    // ------------------------------------------------------------------------------ 
    // CALLBACK FUNCTION FOR: add_action('admin_print_styles-' . $page, array(&$this,'admin_styles')); 
    // ------------------------------------------------------------------------------ 

    // Add menu page styles 
    function admin_style() { 
    wp_enqueue_style('plugin-options',plugins_url('css/options-framework.css', __FILE__)); 
    } 


    // ------------------------------------------------------------------------------ 
    // CALLBACK FUNCTION SPECIFIED IN: add_options_page() 
    // ------------------------------------------------------------------------------ 

    // Render the Plugin options form 
    function render_form() { 
    echo "Bacon!!!"; 
    } 

    // Sanitize and validate input. Accepts an array, return a sanitized array. 
    function validate_options($input) { 

    $clean = array(); 

    // strip html from textboxes 
    $clean['pubid'] = wp_filter_nohtml_kses($input['pubid']); // Sanitize text input (strip html tags, and escape characters) 
    $clean['delete'] = isset($input['delete']) ? 'true' : 'false' ; //checkbox 

    $clean['emailsubject'] = wp_filter_nohtml_kses($input['emailsubject']); // Sanitize text input (strip html tags, and escape characters) 
    $clean['emailmsg'] = wp_filter_post_kses($input['emailmsg']); // Sanitize textbox input (allow tags that area allowed in posts) 

    $clean['twittermsg'] = wp_filter_nohtml_kses($input['twittermsg']); // Sanitize text input (strip html tags, and escape characters) 

    return $clean; 
    } 

    // Display a Settings link on the main Plugins page 
    function add_action_links($links, $file) { 

    if ($file == plugin_basename(__FILE__)) { 
     $posk_links = '<a href="'.admin_url('options-general.php?page=tell-a-friend').'">'.__('Settings', 'kia_tell_a_friend').'</a>'; 
     // make the 'Settings' link appear first 
     array_unshift($links, $posk_links); 
    } 

    return $links; 
    } 


} 

然后在我的第一个插件我打电话(上的init挂钩)

$args = array ('page_title' => 'apple options page', 
         'menu_title' => 'apple options', 
         'capability' => 'manage_options', 
         'menu_slug' => 'apple_options', 
         'setting_name' => 'apple_settings', 
         'option_name' => 'apple_db_options'); 

    $this->options = new KIA_Plugin_Options($args); 

,并在第二插件

$args = array ('page_title' => 'bacon options page', 
        'menu_title' => 'bacon options', 
        'capability' => 'manage_options', 
        'menu_slug' => 'bacon_options', 
        'setting_name' => 'bacon_settings', 
        'option_name' => 'bacon_db_options'); 

$this->options = new KIA_Plugin_Options($args); 

这两个插件都包含在各自的类中。我可以发布其中一个假人,如果这会有所帮助,但它会变得很多代码。

回答

1

根据自己的经验,我可以说,它可以与PHP共享基本类本身,但请记住,Wordpress本身不是面向对象的。

所以当你注册钩子,页面,回调之类的时候,注意你和wordpress本身很容易区分。

例如,在您的插件的基类中,您使用__FILE__来注册挂钩。这个值在所有情况下都是一样的,所以没有用。同样对于一些钩子,你需要一些其他的价值。因此,可能从第一个更轻量级开始,例如没有激活/卸载例程,并使其工作。在管理员只需两页,他们的菜单条目等。一步一步。

然后看一看Breadcrumb NavXT插件。它做了类似的事情,它有一个AdminKi​​t基类,具体的选项页面从中延伸出来。我个人不会说这是完美的,但你看,这可能是有趣:

另外,我建议你不仅扳手一切为基类,但你更创造对象,你需要他们让事情更远离灵活:

希望这能帮助我们将事情恢复运行。

+0

嗨感谢您的提示!我以为我是从我实际想要做的事情中剥离出来的,但你可能是对的,我需要更加简单,然后建立起来,因为我知道发生了什么事。我有一个朋友看看,她显然不能重现我的问题,所以我不知道发生了什么。我很欣赏这些链接,我会在早上阅读它们。 – helgatheviking

相关问题