2012-12-25 61 views
0

任務是爲一個頁面設置特定模板。模板文件被放置在我的插件目錄中,並且我無法找到正確的方式來獲取路徑作爲update_post_meta函數的第三個參數。我創建了新模板,無法從插件文件夾中獲取

我嘗試這樣做:

update_post_meta($pas_tasks_page_id, "_wp_page_template", "task-list-template.php"); 

這一個:

update_post_meta($pas_tasks_page_id, "_wp_page_template", (ABSPATH . "wp-content/plugins/self-manage/task-list-template.php") ); 

但沒有任何工程。我可以在我的插件中創建模板嗎?

回答

1

指向插件目錄中文件的最佳方式是使用plugins_url()

關於你的最後一個問題,你可以在插件中創建菜單頁面(模板)。下面是幾個頁面的示例:

// Put this in your main script 
add_action('admin_menu', 'membership_menu') ; // Register Admin Menus 

// Holds the absolute path to the plugin directory, without trailing slash. 
if (!defined('PLUGIN_DIR')) define('PLUGIN_DIR', __DIR__); 

// Holds the directory name where the plugin was installed, without slashes. 
if (!defined('PLUGIN_DIRNAME')) define('PLUGIN_DIRNAME', basename(PLUGIN_DIR)); 


// And this in the same script or your plugin's functions script. 
    public function membership_menu() { 
     $OptionsPath = PLUGIN_DIRNAME . '/modules/-options.php'; 
     add_menu_page('Membership', 'Membership', 'administrator', $OptionsPath, '', plugins_url('/' . PLUGIN_DIRNAME . '/images/.png')); 
     add_submenu_page($OptionsPath, 'Membership Settings', 'Settings', 'administrator', $OptionsPath, ''); 
} 
+0

我不需要創建菜單頁(模板)的東西。我有一個工作模板文件,我手動粘貼在我的主題(二十幾個)目錄中。但是我想將它放在我的插件文件夾中,但無法設置正確的路徑來使用'update_post_meta'函數。我想這也可能是一個功能問題。 –

+0

我回答了這部分「我可以在我的插件中創建模板嗎?」,還提到了指向插件目錄中文件的最佳方式以及將路徑常量設置爲該目錄的方法。 –

1

CAN從插件添加的頁面模板。

這是我的代碼解決方案(受Tom McFarlin啓發)。

注 - 這是頁面的解決方案,但您還需要配置您的自定義帖子類型以接受頁面模板。

這是爲插件而設計的(在插件的根目錄下搜索模板文件)。這可以根據需要進行更改 - 請查看我的完整教程http://www.wpexplorer.com/wordpress-page-templates-plugin/以獲得有關此解決方案的更多詳細信息。這些文件的格式也與它們直接包含在主題中的格式完全相同。

要自定義,只需編輯__construct方法中的以下代碼塊;

$this->templates = array(
     'goodtobebad-template.php'  => 'It\'s Good to Be Bad', 
    ); 

Full code;

class PageTemplater { 

    /** 
    * A Unique Identifier 
    */ 
    protected $plugin_slug; 

    /** 
    * A reference to an instance of this class. 
    */ 
    private static $instance; 

    /** 
    * The array of templates that this plugin tracks. 
    */ 
    protected $templates; 


    /** 
    * Returns an instance of this class. 
    */ 
    public static function get_instance() { 

      if(null == self::$instance) { 
        self::$instance = new PageTemplater(); 
      } 

      return self::$instance; 

    } 

    /** 
    * Initializes the plugin by setting filters and administration functions. 
    */ 
    private function __construct() { 

      $this->templates = array(); 


      // Add a filter to the attributes metabox to inject template into the cache. 
      add_filter(
       'page_attributes_dropdown_pages_args', 
       array($this, 'register_project_templates') 
      ); 


      // Add a filter to the save post to inject out template into the page cache 
      add_filter(
       'wp_insert_post_data', 
       array($this, 'register_project_templates') 
      ); 


      // Add a filter to the template include to determine if the page has our 
      // template assigned and return it's path 
      add_filter(
       'template_include', 
       array($this, 'view_project_template') 
      ); 


      // Add your templates to this array. 
      $this->templates = array(
        'goodtobebad-template.php'  => 'It\'s Good to Be Bad', 
      ); 

    } 


    /** 
    * Adds our template to the pages cache in order to trick WordPress 
    * into thinking the template file exists where it doens't really exist. 
    * 
    */ 

    public function register_project_templates($atts) { 

      // Create the key used for the themes cache 
      $cache_key = 'page_templates-' . md5(get_theme_root() . '/' . get_stylesheet()); 

      // Retrieve the cache list. 
      // If it doesn't exist, or it's empty prepare an array 
      $templates = wp_get_theme()->get_page_templates(); 
      if (empty($templates)) { 
        $templates = array(); 
      } 

      // New cache, therefore remove the old one 
      wp_cache_delete($cache_key , 'themes'); 

      // Now add our template to the list of templates by merging our templates 
      // with the existing templates array from the cache. 
      $templates = array_merge($templates, $this->templates); 

      // Add the modified cache to allow WordPress to pick it up for listing 
      // available templates 
      wp_cache_add($cache_key, $templates, 'themes', 1800); 

      return $atts; 

    } 

    /** 
    * Checks if the template is assigned to the page 
    */ 
    public function view_project_template($template) { 

      global $post; 

      if (!isset($this->templates[get_post_meta( 
       $post->ID, '_wp_page_template', true 
      )])) { 

        return $template; 

      } 

      $file = plugin_dir_path(__FILE__). get_post_meta( 
       $post->ID, '_wp_page_template', true 
      ); 

      // Just to be safe, we check if the file exist first 
      if(file_exists($file)) { 
        return $file; 
      } 
      else { echo $file; } 

      return $template; 

    } 


} 

add_action('plugins_loaded', array('PageTemplater', 'get_instance')); 

查看我的教程瞭解更多信息。

http://www.wpexplorer.com/wordpress-page-templates-plugin/

我希望這可以幫助你在你想要做的:)