Wordpress按ACF文本字段排序顺序

Wordpress按ACF文本字段排序顺序,wordpress,advanced-custom-fields,Wordpress,Advanced Custom Fields,我遇到了一个问题,我正在尝试使用pre_get_postsby和作为文本字段的ACF字段对我的帖子进行排序 这是我的密码: function my_pre_get_posts( $query ) { // do not modify queries in the admin if( is_admin() ) { return $query; } if( $query->is_main_query() && $query

我遇到了一个问题,我正在尝试使用
pre_get_posts
by和作为文本字段的ACF字段对我的帖子进行排序

这是我的密码:

function my_pre_get_posts( $query ) {

    // do not modify queries in the admin
    if( is_admin() ) {

        return $query;

    }

    if( $query->is_main_query() && $query->is_tax('locations')) {

        $query->set('meta_key', 'level');
        $query->set('orderby', 'meta_value');
        $query->set('order', 'DESC');

    }   

    // return
    return $query;

}

add_action('pre_get_posts', 'my_pre_get_posts');
在ACF配置中,它被设置为文本,文本的值可以是青铜、银、金等

更新 我现在将等级字段改为数字,并将其切换为1=铜牌,2=银牌等

不过,我还是一无所获

当我运行下面的程序时,不会返回任何内容


有什么想法吗?

我认为您可能无意中覆盖了整个查询。请尝试以下(未经测试的)代码段:

请注意,
$query
不会返回


祝你好运

因此,最后将其从functions.php文件切换到分类法模板

这是我完成的代码:

<?php

if(isset($_GET['type'])) {
    if($_GET['type'] == 'villa') {
        $filter = array(
                'key'     => 'type_name',
                'value'   => 'Villa',
                'compare' => '=',
            );
    } elseif ($_GET['type'] == 'apartment') {
        $filter = array(
                'key'     => 'type_name',
                'value'   => 'Apartment',
                'compare' => '=',
            );
    } elseif ($_GET['type'] == 'alls') {
        $filter = array(
            'relation' => 'or',
            array(
                'key'     => 'type_name',
                'value'   => 'Villa',
                'compare' => '=',
            ),
            array(
                'key'     => 'type_name',
                'value'   => 'Apartment',
                'compare' => '=',
            )
        );
    }
}

$paged = (get_query_var('paged')) ? get_query_var('paged') : 1;
$args = array(
    'post_type' => 'properties',
    'post_per_page' => 12,
    'paged' => $paged,
    'meta_key' => 'level',
    'orderby' => 'meta_value',
    'order' => 'DESC',
    'tax_query' => array(
        array(
            'taxonomy' => 'locations',
            'field'    => 'slug',
            'terms'    =>  $term->slug,
        ),
    ),
    'meta_query' => $filter
);
// the query
$the_query = new WP_Query( $args ); ?>

祈祷它能帮助别人

<?php

if(isset($_GET['type'])) {
    if($_GET['type'] == 'villa') {
        $filter = array(
                'key'     => 'type_name',
                'value'   => 'Villa',
                'compare' => '=',
            );
    } elseif ($_GET['type'] == 'apartment') {
        $filter = array(
                'key'     => 'type_name',
                'value'   => 'Apartment',
                'compare' => '=',
            );
    } elseif ($_GET['type'] == 'alls') {
        $filter = array(
            'relation' => 'or',
            array(
                'key'     => 'type_name',
                'value'   => 'Villa',
                'compare' => '=',
            ),
            array(
                'key'     => 'type_name',
                'value'   => 'Apartment',
                'compare' => '=',
            )
        );
    }
}

$paged = (get_query_var('paged')) ? get_query_var('paged') : 1;
$args = array(
    'post_type' => 'properties',
    'post_per_page' => 12,
    'paged' => $paged,
    'meta_key' => 'level',
    'orderby' => 'meta_value',
    'order' => 'DESC',
    'tax_query' => array(
        array(
            'taxonomy' => 'locations',
            'field'    => 'slug',
            'terms'    =>  $term->slug,
        ),
    ),
    'meta_query' => $filter
);
// the query
$the_query = new WP_Query( $args ); ?>