更改特定 Woocommerce 产品类别存档页面的默认排序

Change default sorting for specific Woocommerce product category archive pages

我需要将网站上特定产品类别的默认产品排序选项更改为 "Newness"。我知道您可以转到 WooCommerce > 设置 > 产品 > 显示以全局更改默认排序选项,但这不是我需要做的。我需要这样的东西:

function change_default_sorting_option(){

if(is_product_category('3555')){

//change default sorting option to newness

}

}
add_action('', 'change_default_sorting_option');

我对排序功能的了解不多,所以我不确定从哪里开始。我知道该功能应该放在我的子主题的 functions.php.

假设您在自定义页面模板中工作,这应该相对容易。不完全确定您的方法是否适用于利用 is_page() 强制更改产品的排序,但是......您可以利用全局 WP_Query 创建自定义查询,对您的产品进行排序不管你喜欢什么。这是一个例子:

<?php  
    $args = array(
        'post_type'      => 'product',
        'posts_per_page' => -1, //or... set your post per page and utilize pagination if required.
        'orderby'        => 'title',
        'order'          => 'ASC',
    );

    $loop = new WP_Query( $args );

    while ( $loop->have_posts() ) : $loop->the_post();
        global $product;

        //this is where you can output your products
        //which will be ordered according to the set arguments above.

    endwhile;

    wp_reset_query();
?>

编辑:

如果您正在为特定类别寻找此类功能,我会在您的系统中创建一个新页面并使用 WooCommerce 产品 short-code。您不需要在 functions.php 中添加任何内容或以这种方式挂钩任何内容。以下 short-code 是一个示例,您可以使用它来...例如按标题在特定类别页面上订购您的产品。

[products category="yourcategory" orderby="title" ]

这里是正确的钩子和获取特定产品类别归档页面的方法,默认排序"Newness":

add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_catalog_ordering_args', 20, 1 );
function custom_catalog_ordering_args( $args ) {
    $product_category = 't-shirts'; // <== HERE define your product category

    // Only for defined product category archive page
    if( ! is_product_category($product_category) ) return $args;

    // Set default ordering to 'date ID', so "Newness"
    $args['orderby'] = 'date ID';

    if( $args['orderby'] == 'date ID' )
        $args['order'] = 'DESC'; // Set order by DESC

    return $args;
}

代码进入您的活动子主题(或活动主题)的 function.php 文件。已测试并有效。

这里有更好的可行解决方案

add_filter('woocommerce_get_catalog_ordering_args', 'woocommerce_catalog_orderby');
function woocommerce_catalog_orderby( $args ) {
    if( is_product_category( 'shirts' ) ) {  // <- define category slug- returns true or false
        $args['orderby']  = 'meta_value_num';
        $args['order']    = 'ASC'; // <- order ASC or DESC
        $args['meta_key'] = '_price'; // <- _price is meta_value_num's key - required
    }
    return $args;
}

另请在此处阅读有关 WP_Query order 和 orderby 的信息:https://developer.wordpress.org/reference/classes/wp_query/#order-orderby-parameters