我正在使用JSON API插件来检索json格式的帖子数据,它工作得很好。
现在我想使用相同的插件来检索流行的(浏览量最多的)帖子。我如何才能做到这一点。
发布于 2016-08-17 20:30:48
WordPress不存储每个帖子的视图数量,因此仅使用JSON API是不可能的。您需要在每次加载页面时运行存储在post_meta中的计数,如下所示:
function post_view_count() {
if ( is_single() ) {
$count = get_post_meta( get_the_ID(), 'post_view_count', true ) ?: 0;
update_post_meta( get_the_ID(), 'post_view_count', $count++ );
}
}
add_action( 'wp_head', 'post_view_count' );然后,您可以查询一个帖子的接口,按键'post_view_count‘降序排序。您可能需要添加类似下面这样的内容,以允许使用接口查询post_meta:
function json_allow_meta_query( $valid_vars ) {
$valid_vars = array_merge( $valid_vars, array( 'meta_key', 'meta_value', 'meta_compare' ) );
return $valid_vars;
}
add_filter( 'rest_query_vars', 'json_allow_meta_query' );但是,请注意,您为每个post加载添加了两个数据库命中,这将影响性能。
https://stackoverflow.com/questions/38996050
复制相似问题