从其他文件调用php类

时间:2010-08-06 17:47:21

标签: php wordpress class

我正在研究一些自定义帖子类型。我完成了第一个,并意识到我正在使用的元数据代码可以被其他未来的自定义帖子类型(以及页面,帖子等)重用。所以我将该类放在自己的php文件中,并将其包含在我的子主题的functions.php文件中。我之前从未使用过类,但我想我可以从任何我想要的地方调用该类,因为这就是我为函数所做的事情。相反,我从我的post-types.php文件中调用它并得到以下错误:

“致命错误:在第73行的D:\ helga \ xampp \ htdocs \ plagueround \ wp-content \ themes \ plagueround_new2 \ functions \ post-types.php”中找不到类'My_meta_box'

在我的孩子主题的functions.php中,我已经包含了我班级所在的文件:

define('CHILDTHEME_DIRECTORY', get_stylesheet_directory() . '/');
// Meta Box Class - makes meta boxes
require_once(CHILDTHEME_DIRECTORY . 'functions/meta_box_class.php');

这是我的班级

//My Meta Box CLASS
//from: http://www.deluxeblogtips.com/2010/05/howto-meta-box-wordpress.html

class My_meta_box {

        protected $_meta_box;

        // create meta box based on given data
        function __construct($meta_box) {
        $this->_meta_box = $meta_box;
        add_action('admin_menu', array(&$this, 'add'));

        add_action('save_post', array(&$this, 'save'));
    }

    /// Add meta box for multiple post types
    function add() {
        foreach ($this->_meta_box['pages'] as $page) {
            add_meta_box($this->_meta_box['id'], $this->_meta_box['title'], array(&$this, 'show'), $page, $this->_meta_box['context'], $this->_meta_box['priority']);
        }
    }

    // Callback function to show fields in meta box
    function show() {
        global $post;

        // Use nonce for verification
        echo '<input type="hidden" name="mytheme_meta_box_nonce" value="', wp_create_nonce(basename(__FILE__)), '" />';

        echo '<table class="form-table">';

        foreach ($this->_meta_box['fields'] as $field) {
            // get current post meta data
            $meta = get_post_meta($post->ID, $field['id'], true);

            echo '<tr>',
                    '<th style="width:20%"><label for="', $field['id'], '">', $field['name'], '</label></th>',
                    '<td>';
            switch ($field['type']) {
                case 'text':
                    echo '<input type="text" name="', $field['id'], '" id="', $field['id'], '" value="', $meta ? $meta : $field['std'], '" size="30" style="width:97%" />',
                        '<br />', $field['desc'];
                    break;
                case 'textarea':
                    echo '<textarea name="', $field['id'], '" id="', $field['id'], '" cols="60" rows="4" style="width:97%">', $meta ? $meta : $field['std'], '</textarea>',
                        '<br />', $field['desc'];
                    break;
                case 'select':
                    echo '<select name="', $field['id'], '" id="', $field['id'], '">';
                    foreach ($field['options'] as $option) {
                        echo '<option', $meta == $option ? ' selected="selected"' : '', '>', $option, '</option>';
                    }
                    echo '</select>';
                break;
                case 'select2': //for when value and display text don't match
                                //$options array must be multidimensional with both the 'value' and the 'text' for each option
                                //for example = array( array(text=>text1,value=>value1),array(text=>text2,value=>value2))
                                //then in <option> value = $option['value'] and text = $option['text']
                    echo '<select name="', $field['id'], '" id="', $field['id'], '">';
                    foreach ($field['options'] as $option) {
                        echo '<option value="',$option['value'],'"', $meta == $option['value'] ? ' selected="selected"' : '', '>', $option['desc'], '</option>';
                    }
                    echo '</select>';
                    break;
                case 'radio':
                    foreach ($field['options'] as $option) {
                        echo '<input type="radio" name="', $field['id'], '" value="', $option['value'], '"', $meta == $option['value'] ? ' checked="checked"' : '', ' />', $option['name'];
                    }
                    break;
                case 'checkbox':
                    echo '<input type="checkbox" name="', $field['id'], '" id="', $field['id'], '"', $meta ? ' checked="checked"' : '', ' />';
                    break;
            }
            echo    '<td>',
                '</tr>';
        }

        echo '</table>';
    }

    // Save data from meta box
    function save($post_id) {
        // verify nonce
        if (!wp_verify_nonce($_POST['mytheme_meta_box_nonce'], basename(__FILE__))) {
            return $post_id;
        }

        // check autosave
        if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE) {
            return $post_id;
        }

        // check permissions
        if ('page' == $_POST['post_type']) {
            if (!current_user_can('edit_page', $post_id)) {
                return $post_id;
            }
        } elseif (!current_user_can('edit_post', $post_id)) {
            return $post_id;
        }

        foreach ($this->_meta_box['fields'] as $field) {
            $old = get_post_meta($post_id, $field['id'], true);
            $new = $_POST[$field['id']];

            if ($new && $new != $old) {
                update_post_meta($post_id, $field['id'], $new);
            } elseif ('' == $new && $old) {
                delete_post_meta($post_id, $field['id'], $old);
            }
        }
    }
}

然后在我的post-types.php文件中我定义了一些自定义帖子类型的元框:

$prefix = '_events_';
$post_id = $_GET['post'] ? $_GET['post'] : $_POST['post_ID'] ;

$events_meta_box = array(
    'id' => 'wpt_events',
    'title' => 'Events Options',
    'pages' => array('events'), // multiple post types possible
    'context' => 'side',
    'priority' => 'low',
    'fields' => array(
        array(
            'name' => 'Headline',
            'desc' => 'Enter the heading you\'d like to appear before the video',
            'id' => $prefix . 'heading1',
            'type' => 'text',
            'std' => ''
        ),

    )

);

$my_box = new My_meta_box($events_meta_box); 

那么我如何引用其他文件中的类?

EDITS / CONTINUATION

只需将require_once语句移动到post-types.php(试图调用该类的那个)就好了。但是对于它,我尝试了自动加载脚本

function __autoload($className)
{
        require(CHILDTHEME_DIRECTORY .'functions/class_' . $className . '.php')  ;
}

我将我的类文件重命名为class_My_meta_box.php,而My_meta_box是类名

导致以下错误: 警告:require(D:\ helga \ xampp \ htdocs \ plagueround / wp-content / themes / plagueround_new / functions / class_WP_User_Search.php)[function.require]:无法打开流:D:\ helga中没有这样的文件或目录第66行\ xampp \ htdocs \ plagueround \ wp-content \ themes \ plagueround_new \ functions.php

致命错误:require()[function.require]:打开所需的'D:\ helga \ xampp \ htdocs \ plagueround / wp-content / themes / plagueround_new / functions / class_WP_User_Search.php'(include_path ='。;第66行的D:\ helga \ xampp \ htdocs \ plagueround \ wp-content \ themes \ plagueround_new \ functions.php中的D:\ helga \ xampp \ php \ PEAR'

我不完全理解它的内容,但我认为它试图自动加载一些默认的wordpress类......并且正在我的目录中查看它显然不存在。

4 个答案:

答案 0 :(得分:4)

实际上,如果文件包含类或其他内容则无关紧要。为了使PHP能够从其他文件执行代码,PHP必须知道文件的位置,因此它是您的常规requireinclude

示例:

// foo.class.php
class Foo {}

// main.php
require_once '/path/to/foo.class.php';
$foo = new Foo;

使用课程时,use a Naming Convention实际上是有意义的,并使用Autoloader,所以PHP will try to include the class on it's own,而不必要求或包含它。

答案 1 :(得分:1)

您可以使用常量WP_PLUGIN_DIR来描述路径。

// Foo.class.php
class Foo {}

// main.php
require_once WP_PLUGIN_DIR.'/Foo.class.php';
$foo = new Foo;

答案 2 :(得分:0)

只需使用绝对路径:

require_once("fullpath/functions/meta_box_class.php") or die ("Could Not load file");

答案 3 :(得分:0)

看起来meta_box_class.php未包含在内。要找出随时包含的文件,请尝试:

var_dump(get_included_files());