2015-04-23 81 views
2

我有自定义帖子类型“soto_property”。我已经根据使用的名为“operations”的元数据制作了一个自定义过滤器来过滤帖子列表。这是我的代码 -自定义过滤器功能不适用于自定义帖子类型

<?php 
add_filter('parse_query', 'soto_posts_filter'); 
add_action('restrict_manage_posts', 'soto_posts_filter_restrict_manage_posts'); 

function soto_posts_filter($query) 
{ 
    global $pagenow; 
    if(is_admin() AND $query->query['post_type'] == 'soto_property') { 
     $qv = &$query->query_vars; 
     $qv['meta_query'] = array(); 

     if(!empty($_GET['operations'])) { 
      $qv['meta_query'][] = array(
      'field' => 'operations', 
      'value' => $_GET['operations'], 
      'compare' => 'LIKE', 
     ); 
     } 

    } 
} 

function soto_posts_filter_restrict_manage_posts() 
{ 
    global $wpdb; 
    if($_GET['post_type']=='soto_property') 
    { 
     $sql = 'SELECT DISTINCT meta_key FROM '.$wpdb->postmeta.' where meta_key="operations" ORDER BY 1'; 
     $fields = $wpdb->get_results($sql, ARRAY_N); 

?> 
<select name="operations" id="filter-operations" class="custom-filter" style="display:none; width: 15%;" > 
     <option value=""></option> 
     <option value="2" <?php echo $_GET['operations']==2?"selected='selected'":'' ?>>Rent</option> 
     <option value="1" <?php echo $_GET['operations']==1?"selected='selected'":'' ?>>Sale</option> 
     </select> 
<?php 
    } 
} 

但我的文章没有根据元数据“操作”过滤。 此元数据存储在wp_postmeta DB表中,其中meta_key=operationmeta_value=1meta_value=2

任何人都可以帮助我。

+0

请注意,使用从$ _GET和$ _POST获得的值而不消毒它们是很危险的。你可能想检查:http://codex.wordpress.org/Validating_Sanitizing_and_Escaping_User_Data – Maxime

回答

0

多东西是你的代码错误:

  1. 你不应该不消毒它们使用从用户($_GET$_POST$_REQUEST)得到的值。您应该阅读:Validating Sanitizing and Escaping User Data
  2. 您在功能soto_posts_filter_restrict_manage_posts中的选择语句是无用的,因为您无需执行任何操作。此外,您的<select>代码表明只能使用一个值,为什么使用DISTINCT?另外,该声明是否应该链接到帖子ID?

这当然是为什么你没有得到你期待的结果。我建议您在这里和那里添加一些var_dump并验证您的流程中的每个步骤,以确保您始终具有预期的结果。

相关问题