在Wordpress Woocommerce中,我创建了一个分组产品,其中包含许多子产品(子产品)。我试着到处搜索,但我找不到一个有效的解决方案,如何按SKU或产品名称进行订购。它的orderby似乎只由“菜单顺序”生成。虽然我在这些多个分组的产品中有30个子产品,但按菜单顺序值来订购它们是非常浪费时间的。
我尝试了以下代码,但它似乎在WC2.5中工作,而不是在3.0中。
add_filter( 'woocommerce_grouped_children_args',
'so_22661392_grouped_children_args' );
function so_22661392_grouped_children_args( $args ){
$args['meta_key'] = 'sku';
$args['orderby'] = 'meta_value';
$args['order'] = 'ASC';
return $args;
}
我也在谷歌上搜索解释,但找不到任何解释。我试图清除瞬变,但效果不好:
WooCommerce>System Status>Tools>Clear Transients
分组后的产品可以在上看到https://plastmet.ee/uus/toode/umartoru-kork-zzo-pealekaiv/。html表应与下面的子项匹配,但不匹配。儿童SKU为“563/9005”、“567/9005”等。。
任何帮助都将不胜感激!
希望我能正确理解这个问题:
如果我们重写了模板文件单品/加载到购物车/grouped.php
,那么我们可以使用例如:
if( $grouped_products )
usort( $grouped_products, 'wc_products_array_orderby_title' );
按标题而不是默认菜单顺序对分组产品进行排序。
我们也可以取消注册:
add_action( 'woocommerce_grouped_add_to_cart', 'woocommerce_grouped_add_to_cart', 30 );
而是使用自定义回调。
作为最后的手段,可以重写woocommerce_grouped_add_to_cart()
函数,例如在插件中,以更改菜单顺序。
它的定义是:
if ( ! function_exists( 'woocommerce_grouped_add_to_cart' ) ) {
function woocommerce_grouped_add_to_cart() {
global $product;
$products = array_filter( array_map( 'wc_get_product', $product->get_children() ) );
if ( $products ) {
usort( $products, 'wc_products_array_orderby_menu_order' );
wc_get_template( 'single-product/add-to-cart/grouped.php', array(
'grouped_product' => $product,
'grouped_products' => $products,
'quantites_required' => false,
) );
}
}
}
例如,可以使用wc_products_array_orderby_title
来代替。