首先,您需要在 woocommerce_get_catalog_ordering_args 挂钩中挂钩的自定义函数中定义 'rating-asc' 排序选项参数。
由于存在排序选项“按平均评分排序”,如果您查看默认现有参数以按“评分”键对产品进行排序,则您拥有该数组:
$args = array(
'orderby' => array(
'meta_value_num' => 'DESC',
'ID' => 'ASC'
),
'order' => 'ASC',
'meta_key' => '_wc_average_rating'
);
所以您只需将'meta_value_num' => 'DESC' 更改为'meta_value_num' => 'ASC',那么您正确的工作代码将是:
add_filter( 'woocommerce_get_catalog_ordering_args', 'enable_catalog_ordering_by_ratings' );
function enable_catalog_ordering_by_ratings( $args ) {
if ( isset( $_GET['orderby'] ) && 'rating-asc' === $_GET['orderby']
&& isset($args['orderby']['meta_value_num']) ) {
$args['orderby']['meta_value_num'] = 'ASC';
}
return $args;
}
现在您可以在 “按平均评分排序” 现有选项之后插入新的排序选项,例如:
add_filter( 'woocommerce_catalog_orderby', 'catalog_orderby_ratings_asc_filter' );
function catalog_orderby_ratings_asc_filter( $options ){
$sorted_options =[];
foreach( $options as $key => $label ){
if( 'rating' === $key ) {
$sorted_options['rating'] = $options['rating'] . ' ' . __('(Desc)', 'woocommerce');
$sorted_options['rating-asc'] = $options['rating'] . ' ' . __('(Asc)', 'woocommerce');
} else {
$sorted_options[$key] = $label;
}
}
return $sorted_options;
}
代码进入您的活动子主题(或活动主题)的 function.php 文件中。经过测试并且可以工作。
相关: