wordpress WooCommerce中的多个订单

xzlaal3s  于 2023-11-17  发布在  WordPress
关注(0)|答案(2)|浏览(159)

我想订购我的产品在类别页面的平均评级(DESC),然后按价格(ASC)。

| id  |  avgrating   |   price   |
|  1  |      4       |     10    |
|  2  |      4       |      5    |
|  3  |      5       |      7    |

字符串
顺序:三,二,一。
所以我试着:

$args['meta_key'] = '_wc_average_rating';
$args['orderby']  = array(
    'meta_value_num' => 'DESC',
    'price' => 'ASC',
);


但是它们不是按价格排序的。我也用_price替换了price,结果一样。
我使用的是最新版本的WordPress(4.8)和WooCommerce(3.0.8)。

编辑:

如果我用途:

$args['meta_key'] = '_wc_average_rating';
$args['orderby']  = array(
    'meta_value_num' => 'DESC',
    'ID'             => 'DESC',
);


顺序工程作为例外,DESC的平均评级,然后DESC的ID。所以,我必须改变IDprice,但我不能使它工作。

xa9qqrwz

xa9qqrwz1#

通过传递带有参数的order进行检查
看看这些

add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_woocommerce_get_catalog_ordering_args' );

function custom_woocommerce_get_catalog_ordering_args( $args ) {
  $orderby_value = isset( $_GET['orderby'] ) ? woocommerce_clean( $_GET['orderby'] ) : apply_filters( 'woocommerce_default_catalog_orderby', get_option( 'woocommerce_default_catalog_orderby' ) );
    if ( 'sort_by_type' == $orderby_value ) {
        $args['orderby'] = 'meta_value_num title';
        $args['order'] = 'ASC';
        $args['meta_key'] = 'sort_by_type';

    }

    if ( '_wc_average_rating' == $orderby_value ) {
        $args['orderby'] = 'meta_value_num title';
        $args['order'] = 'DESC';
        $args['meta_key'] = '_wc_average_rating';
    }

    return $args;
}

字符串

shstlldc

shstlldc2#

我想订购的产品首先由日期然后缺货的项目是在年底。我尝试了下面的代码。但不工作。

add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_woocommerce_get_catalog_ordering_args' );

function custom_woocommerce_get_catalog_ordering_args( $args ) {
$orderby_value = isset( $_GET['orderby'] ) ? woocommerce_clean( $_GET['orderby'] ) : apply_filters( 'woocommerce_default_catalog_orderby', get_option( 'woocommerce_default_catalog_orderby' ) );
if ( 'sort_by_date' == $orderby_value ) {
$args['orderby'] = 'meta_value';
$args['order'] = 'ASC';
$args['meta_key'] = 'sort_by_date';

}
if ( '_stock_status' == $orderby_value ) {
$args['orderby'] = 'meta_value';
 $args['order'] = 'DESC';
$args['meta_key'] = '_stock_status';
}
 return $args;
}

字符串

相关问题