如何使用自定义域(搜索功能)过滤帖子列表(在WP仪表板帖子列表中)?

时间:2011-05-07 作者:jean04

尽管我经常在谷歌上搜索,但我还没有找到一个非常简单的问题的答案:

我有一些带有自定义字段(即供应商名称)的帖子。我想能够搜索和筛选我的帖子根据这个自定义字段。换句话说,在admin posts列表中,我希望有一个搜索框(名为“Supplier name”),我可以在其中键入一个值(例如“IBM”),然后单击一个搜索按钮,将返回所有具有名为“Supplier\\u name”的自定义字段的帖子,如果是,自定义字段的值将为“IBM”。

我该怎么做?

1 个回复
SO网友:Bainternet

我为此编写了一个插件,但从未发布过:

enter image description here

用法:

在下拉列表中,您有一个所有自定义字段的列表,因此只需选择要筛选的字段,然后单击“筛选”。如果要筛选到自定义字段的特定值,请选择该字段的名称,输入所需的值,然后单击“筛选”。

<?php
/*
Plugin Name: Admin Filter BY Custom Fields
Plugin URI: http://en.bainternet.info
Description: Filter posts or pages in admin by custom fields (post meta)
Version: 1.0
Author: Bainternet
Author URI: http://en.bainternet.info
*/



add_filter( \'parse_query\', \'ba_admin_posts_filter\' );
add_action( \'restrict_manage_posts\', \'ba_admin_posts_filter_restrict_manage_posts\' );

function ba_admin_posts_filter( $query )
{
    global $pagenow;
    if ( is_admin() && $pagenow==\'edit.php\' && isset($_GET[\'ADMIN_FILTER_FIELD_NAME\']) && $_GET[\'ADMIN_FILTER_FIELD_NAME\'] != \'\') {
        $query->query_vars[\'meta_key\'] = $_GET[\'ADMIN_FILTER_FIELD_NAME\'];
    if (isset($_GET[\'ADMIN_FILTER_FIELD_VALUE\']) && $_GET[\'ADMIN_FILTER_FIELD_VALUE\'] != \'\')
        $query->query_vars[\'meta_value\'] = $_GET[\'ADMIN_FILTER_FIELD_VALUE\'];
    }
}

function ba_admin_posts_filter_restrict_manage_posts()
{
    global $wpdb;
    $sql = \'SELECT DISTINCT meta_key FROM \'.$wpdb->postmeta.\' ORDER BY 1\';
    $fields = $wpdb->get_results($sql, ARRAY_N);
?>
<select name="ADMIN_FILTER_FIELD_NAME">
<option value=""><?php _e(\'Filter By Custom Fields\', \'baapf\'); ?></option>
<?php
    $current = isset($_GET[\'ADMIN_FILTER_FIELD_NAME\'])? $_GET[\'ADMIN_FILTER_FIELD_NAME\']:\'\';
    $current_v = isset($_GET[\'ADMIN_FILTER_FIELD_VALUE\'])? $_GET[\'ADMIN_FILTER_FIELD_VALUE\']:\'\';
    foreach ($fields as $field) {
        if (substr($field[0],0,1) != "_"){
        printf
            (
                \'<option value="%s"%s>%s</option>\',
                $field[0],
                $field[0] == $current? \' selected="selected"\':\'\',
                $field[0]
            );
        }
    }
?>
</select> <?php _e(\'Value:\', \'baapf\'); ?><input type="TEXT" name="ADMIN_FILTER_FIELD_VALUE" value="<?php echo $current_v; ?>" />
<?php
}

结束