最近给一个客户二次开发主题,需要加多条件筛选,其中有个筛选就是根据文章的某个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