通过 WooCommerce 中的挂钩函数对订单项目进行排序
Sorting order items via a hooked function in WooCommerce
在 WooCommerce 中,我有一个 "location" 的产品属性 pa_location
,用于对我的订单商品进行排序。当订单商品的位置相同时,我想按 SKU 对它们进行排序。所以,先按位置排序,然后按 SKU 排序。
我查看了 "PHP usort sorting multiple fields",但我无法弄清楚它如何适用于我的功能。
我有这个自定义函数可以按 pa_location
排序,但不能让它也按 _sku
排序。
我尝试在引用的 post 中实现一些关于排序的示例。
add_filter( 'woocommerce_order_get_items', function( $items, $order ) {
uasort( $items,
function( $a, $b ) {
return strnatcmp( $a['pa_location'], $b['pa_location'] );
}
);
return $items;
}, 10, 2 );
我希望使用此功能先按位置然后按SKU 排序。目前仅按位置排序。
试试这个:
add_filter( 'woocommerce_order_get_items', function( $items, $order ) {
uasort( $items,
function( $a, $b ) {
return strnatcmp( $a['pa_location'], $b['pa_location'] );
}
);
uasort( $items,
function( $a, $b ) {
return strnatcmp( $a['_sku'], $b['_sku'] );
}
);
return $items;
}, 10, 2 );
我已经为 _sku
重新运行了 uasort()
。我没有测试代码,但我希望它可以为您完成工作。
根据 "PHP usort sorting multiple fields" 回答主题尝试以下操作:
add_filter( 'woocommerce_order_get_items', 'filter_order_get_items_callback', 10, 2 );
function filter_order_get_items_callback( $items, $order ) {
uasort( $items,
function( $a, $b ) {
if( $a['pa_location'] == $b['pa_location'] ) {
return strcmp( $a['_sku'], $b['_sku'] );
}
return strnatcmp( $a['pa_location'], $b['pa_location'] );
}
);
return $items;
}
测试中:
$items = array (
0 => array ( 'pa_location' => 'Marseille',
'_sku' => '27458C' ),
1 => array ( 'pa_location' => 'Nice',
'_sku' => '32458A' ),
2 => array ('pa_location' => 'Cannes',
'_sku' => '35C7L5' ),
3 => array ('pa_location' => 'Marseille',
'_sku' => '387B85'),
4 => array ( 'pa_location' => 'Cannes',
'_sku' => '25A587' )
);
uasort( $items, function( $a, $b ) {
if( $a['pa_location'] == $b['pa_location'] ) {
return strcmp( $a['_sku'], $b['_sku'] );
}
return strnatcmp( $a['pa_location'], $b['pa_location'] );
} );
// Raw output
echo '<pre>'; print_r( $items ); echo '<pre>';
我们得到这个输出:
Array
(
[2] => Array
(
[pa_location] => Cannes
[_sku] => 25A587
)
[4] => Array
(
[pa_location] => Cannes
[_sku] => 35C7L5
)
[0] => Array
(
[pa_location] => Marseille
[_sku] => 27458C
)
[3] => Array
(
[pa_location] => Marseille
[_sku] => 387B85
)
[1] => Array
(
[pa_location] => Nice
[_sku] => 32458A
)
)
这就是我们所期望的,排序在 pa_location
之前,在 _sku
之后。
在 WooCommerce 中,我有一个 "location" 的产品属性 pa_location
,用于对我的订单商品进行排序。当订单商品的位置相同时,我想按 SKU 对它们进行排序。所以,先按位置排序,然后按 SKU 排序。
我查看了 "PHP usort sorting multiple fields",但我无法弄清楚它如何适用于我的功能。
我有这个自定义函数可以按 pa_location
排序,但不能让它也按 _sku
排序。
我尝试在引用的 post 中实现一些关于排序的示例。
add_filter( 'woocommerce_order_get_items', function( $items, $order ) {
uasort( $items,
function( $a, $b ) {
return strnatcmp( $a['pa_location'], $b['pa_location'] );
}
);
return $items;
}, 10, 2 );
我希望使用此功能先按位置然后按SKU 排序。目前仅按位置排序。
试试这个:
add_filter( 'woocommerce_order_get_items', function( $items, $order ) {
uasort( $items,
function( $a, $b ) {
return strnatcmp( $a['pa_location'], $b['pa_location'] );
}
);
uasort( $items,
function( $a, $b ) {
return strnatcmp( $a['_sku'], $b['_sku'] );
}
);
return $items;
}, 10, 2 );
我已经为 _sku
重新运行了 uasort()
。我没有测试代码,但我希望它可以为您完成工作。
根据 "PHP usort sorting multiple fields" 回答主题尝试以下操作:
add_filter( 'woocommerce_order_get_items', 'filter_order_get_items_callback', 10, 2 );
function filter_order_get_items_callback( $items, $order ) {
uasort( $items,
function( $a, $b ) {
if( $a['pa_location'] == $b['pa_location'] ) {
return strcmp( $a['_sku'], $b['_sku'] );
}
return strnatcmp( $a['pa_location'], $b['pa_location'] );
}
);
return $items;
}
测试中:
$items = array (
0 => array ( 'pa_location' => 'Marseille',
'_sku' => '27458C' ),
1 => array ( 'pa_location' => 'Nice',
'_sku' => '32458A' ),
2 => array ('pa_location' => 'Cannes',
'_sku' => '35C7L5' ),
3 => array ('pa_location' => 'Marseille',
'_sku' => '387B85'),
4 => array ( 'pa_location' => 'Cannes',
'_sku' => '25A587' )
);
uasort( $items, function( $a, $b ) {
if( $a['pa_location'] == $b['pa_location'] ) {
return strcmp( $a['_sku'], $b['_sku'] );
}
return strnatcmp( $a['pa_location'], $b['pa_location'] );
} );
// Raw output
echo '<pre>'; print_r( $items ); echo '<pre>';
我们得到这个输出:
Array
(
[2] => Array
(
[pa_location] => Cannes
[_sku] => 25A587
)
[4] => Array
(
[pa_location] => Cannes
[_sku] => 35C7L5
)
[0] => Array
(
[pa_location] => Marseille
[_sku] => 27458C
)
[3] => Array
(
[pa_location] => Marseille
[_sku] => 387B85
)
[1] => Array
(
[pa_location] => Nice
[_sku] => 32458A
)
)
这就是我们所期望的,排序在 pa_location
之前,在 _sku
之后。