0

我在我的 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');
4

1 回答 1

0

根据 allaire 的建议,关闭它并转到https://wordpress.stackexchange.com/ 。

对于遇到此问题的任何人,helenhousandi 都有正确的解决方案。https://wordpress.stackexchange.com/a/52408/16201

于 2012-05-17T11:42:01.660 回答