更改特定 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
我需要将网站上特定产品类别的默认产品排序选项更改为 "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