将所有特定订单项自定义字段的总和保存为 WooCommerce 中的订单元数据
Save the sum of all specific order item custom fields as order meta data in WooCommerce
接着我之前的问题”
" ,下订单时,一些订单项自定义元数据 quantity
、assemblycost
和 calculated_field
(其值为保存到 quantity
x assemblycost
)。
如何将所有订单项 calculated_field
值的总和另存为自定义订单元数据?
例如,示例订单如下所示:
Product A:
assemblycost: 10
quantity: 2
calculated_field: 20
Product B:
assemblycost: 15
quantity: 2
calculated_field: 30
Product C:
no assemblycost, quanity or calculated_field - custom fields present.
Product D:
assemblycost: 30
quantity: 2
calculated_field: 60
我想为订单 sum_calculated_fields
创建一个新的自定义字段,并将其设置为等于订单中 calculated_fields
的总和,因此在上面的示例中它将等于:
20+30+60 = 110。
更新:这是对所有订单项目 calculated_fields
自定义字段求和并将该总和保存为自定义订单元数据的方法:
add_action( 'woocommerce_checkout_create_order', 'action_checkout_create_order_callback', 10, 2 );
function action_checkout_create_order_callback( $order, $data ) {
$calculated_fields_sum = 0; // Initializing
// Loop Through order items
foreach ( $order->get_items() as $item ) {
if( $value = $item->get_meta('calculated_field') ) {
$calculated_fields_sum += $value;
}
}
// Update order meta data
if( $calculated_fields_sum > 0 ) {
$order->update_meta_data( 'calculated_fields_sum', $calculated_fields_sum );
}
}
代码进入您的活动子主题(或活动主题)的 function.php 文件。它应该可以工作。
接着我之前的问题”
quantity
、assemblycost
和 calculated_field
(其值为保存到 quantity
x assemblycost
)。
如何将所有订单项 calculated_field
值的总和另存为自定义订单元数据?
例如,示例订单如下所示:
Product A:
assemblycost: 10
quantity: 2
calculated_field: 20
Product B:
assemblycost: 15
quantity: 2
calculated_field: 30
Product C:
no assemblycost, quanity or calculated_field - custom fields present.
Product D:
assemblycost: 30
quantity: 2
calculated_field: 60
我想为订单 sum_calculated_fields
创建一个新的自定义字段,并将其设置为等于订单中 calculated_fields
的总和,因此在上面的示例中它将等于:
20+30+60 = 110。
更新:这是对所有订单项目 calculated_fields
自定义字段求和并将该总和保存为自定义订单元数据的方法:
add_action( 'woocommerce_checkout_create_order', 'action_checkout_create_order_callback', 10, 2 );
function action_checkout_create_order_callback( $order, $data ) {
$calculated_fields_sum = 0; // Initializing
// Loop Through order items
foreach ( $order->get_items() as $item ) {
if( $value = $item->get_meta('calculated_field') ) {
$calculated_fields_sum += $value;
}
}
// Update order meta data
if( $calculated_fields_sum > 0 ) {
$order->update_meta_data( 'calculated_fields_sum', $calculated_fields_sum );
}
}
代码进入您的活动子主题(或活动主题)的 function.php 文件。它应该可以工作。