我想按日期或其他一些参数对woocommerce交叉销售中的产品进行分类。现在,产品以字母顺序显示。我找到了一种解决方案:
add_filter( 'woocommerce_cross_sells_orderby', 'custom_cross_sells_orderby', 10, 1 );
function custom_cross_sells_orderby( $orderby ){
$orderby = 'date';
return $orderby;
}
但是当我在我中添加此代码时,出现functions.php错误505。也许你知道为什么吗?还是您知道其他解决方案?谢谢。
答案 0 :(得分:1)
只需在主题文件夹的名为functions.php的文件中添加以下代码:
<?php
// Filters
add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_woocommerce_get_catalog_ordering_args' );
add_filter( 'woocommerce_cross_sells_orderby', 'custom_woocommerce_catalog_orderby' );
// Apply custom args to main query
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 ( 'oldest_to_recent' == $orderby_value ) {
$args['orderby'] = 'date';
$args['order'] = 'ASC';
}
return $args;
}
// Create new sorting method
function custom_woocommerce_catalog_orderby( $sortby ) {
$sortby['oldest_to_recent'] = __( 'Oldest to most recent', 'woocommerce' );
return $sortby;
}