我在我的 WP 帖子上设置了一些元变量。我希望能够按这些变量进行排序,除了按“视图”或“喜欢”排序时,一切都很好。当我按这两个字段中的任何一个进行排序时,WP 不会生成我的导航(wp_nav_menu)。
我尝试“重置”围绕我的 wp_nav_menu 调用的 $wp_query 变量:
$old_query = $wp_query;
$wp_query = new WP_Query( array('post_type' => 'any') );
wp_nav_menu( array( 'container_class' => 'menu-header', 'theme_location' => 'primary' ) );
$wp_query = $old_query;
但这并不能解决问题。唯一有效的方法是注释掉以 $query->query_vars['meta_key'] 开头的行,但显然这也否定了排序。
任何帮助,将不胜感激。
// Before a query is run, modify the sort order
function jh_popularity_sort_query($query) {
$sort = $_GET['sort'];
if ($sort == "title") {
$query->query_vars['orderby'] = 'title';
$query->query_vars['order'] = 'ASC';
} else if ($sort == "date") {
$query->query_vars['orderby'] = 'date';
} else if ($sort == "views") {
$query->query_vars['meta_key'] = 'jh_page_views';
$query->query_vars['orderby'] = 'meta_value';
$query->query_vars['order'] = 'DESC';
} else if ($sort == "likes") {
$query->query_vars['meta_key'] = 'jh_page_likes';
$query->query_vars['orderby'] = 'meta_value';
$query->query_vars['order'] = 'DESC';
}
return $query;
} add_action('pre_get_posts', 'jh_popularity_sort_query');