WordPress 根据post_meta排序文章(当meta_key不存在时)

最近给一个客户二次开发主题,需要加多条件筛选,其中有个筛选就是根据文章的某个post_meta值进行排序,一般的方法是:

$args = array(   'paged' => $paged   );   $args['meta_key'] = 'favorites'; //这个就是post_meta   $args['orderby'] = 'meta_value_num';   query_posts($args);

但是以上代码有个问题,当文章没有此post_meta时,是不会显示出来的,这个很尴尬吧~那个解决方案如下:

$args = array(   'paged' => $paged   );   //$args['meta_key'] = 'favorites'; //这个就是post_meta   $args['meta_query'] = array();   array_push($args['meta_query'], array(   'relation' => 'OR',   'exist_clause' => array(   'key' => 'favorites',   'compare' => 'EXISTS'   ),   'not_exist_clause' => array(   'key' => 'favorites',   'compare' => 'NOT EXISTS'   ),   ) );   $args['orderby'] = 'meta_value_num';   query_posts($args);

来源地址:WordPress 根据post_meta排序文章(当meta_key不存在时)

转载声明:本站文章若无特别说明,皆为原创,转载请注明来源:www.88531.cn资享网,谢谢!^^

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享