【问题标题】:WP archives order by custom meta keyWP 按自定义元键归档顺序
【发布时间】:2015-08-02 09:45:46
【问题描述】:

在 Wordpress 模板的 function.php 下面的代码运行良好

// Function accepting current query
function my_change_order( $query ) {
    // Check if the query is for an archive
    if($query->is_archive())
        // Query was for archive, then set order
        $query->set( 'order' , 'asc' );
    // Return the query (else there's no more query, oops!)
    return $query;
}
// Runs before the posts are fetched
add_filter( 'pre_get_posts' , 'my_change_order' );

但我需要通过自定义元键(如 _my_meta_vip)来订购文章。基于this answer,我尝试了以下几行,但成功了一半,因为只加载具有定义的自定义元键的文章,其他的则丢失了。我该如何解决?

function my_change_order( $query ) {
    if($query->is_archive())
        $query->set( 'orderby' , 'meta_value' );
        $query->set( 'meta_key' , '_my_meta_vip' );
    return $query;
}
add_filter( 'pre_get_posts' , 'my_change_order' );

如何通过自定义元键正确排序我的文章?

【问题讨论】:

    标签: php wordpress


    【解决方案1】:

    看起来这里的根本问题是查询正在对帖子和 postmeta 表进行内部联接,这就是查询不返回没有特定帖子元条目的帖子的原因。你想要的是左连接。有关差异的说明,请参阅 this answer

    您应该能够使用posts_join 过滤器将内连接替换为左连接:

    add_filter('posts_join', function($join) {
        global $wpdb;
    
        // Replace inner join with left join
        $search = 'INNER JOIN ' . $wpdb->postmeta;
        $replace = 'LEFT JOIN ' . $wpdb->postmeta;
        $join = str_ireplace($search, $replace, $join);
    
        return $join;
    });
    

    【讨论】:

      【解决方案2】:
         function my_change_order( $query ) {
              // Check if the query is for an archive
              if($query->is_archive())
              // Query was for archive, then set order
              $query->set( 'order' , 'asc' );
              $query->set( 'meta_query', array(
                  array(
                    'key' => '_my_meta_vip'
                  )
              ));
      
              // Return the query (else there's no more query, oops!)
              return $query;
          }
      

      看下面的话题:https://wordpress.stackexchange.com/questions/20237/using-meta-query-how-can-i-filter-by-a-custom-field-and-order-by-another-one可能会给你一个清晰的思路

      【讨论】:

      • 我看不出区别,我的代码和我的代码一样。 :(
      • 看到 meta_query 是 send 是 assign & send through array
      • 仍然不显示未定义 _my_meta_vip 的帖子。
      【解决方案3】:

      最后找不到任何方法来列出所有定义了_my_meta_VIP 的帖子。

      在我的解决方案中,所有_my_meta_VIP 都填充了enableddisabled,下面的代码可以完成这项工作:

          // Function accepting current query
          function my_change_order( $query ) {
              // Check if the query is for an archive
              if($query->is_archive()) {
                  // Query was for archive, then set order
                  $query->set( 'post_type', 'profile' );
                  $query->set( 'orderby' , 'meta_value' );
                  $query->set( 'meta_key' , '_my_meta_vip' );
                  $query->set( 'order', 'DESC' );
              } else {
                  // Return the original query for non-archive pages
                  return $query;
              }
              // Return the query
              return $query;
          }
          // Runs before the posts are fetched
          add_filter( 'pre_get_posts' , 'my_change_order' );
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2013-04-25
        • 1970-01-01
        • 1970-01-01
        • 2011-09-03
        • 1970-01-01
        • 2018-06-02
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多