我使用wc_customer_bought_product()
功能检查当前用户是否购买了某种产品。
但是,现在我需要检查客户购买的该产品的数量。
因此,例如,如果我在订单中购买了数量为7的产品,我需要一种方法来获得该产品的订单和订单数量。
我怎样才能做到这一点?
如果有人有答案,我将不胜感激。
答案 0 :(得分:3)
这里有所有材料来构建自己的功能。下面是一个示例,其中包含一个函数,该函数将使用函数wc_customer_bought_product()
基于当前客户的产品ID获取订单中的产品数量:
function checking_product_bought( $_product_id ){
global $woocommerce, $posts;
// Get the current customer info (as an object)
$customer = wp_get_current_user();
$customer_id = $customer->ID; // customer ID
$customer_email = $customer->email; // customer email
// Get all orders for this customer_id
$customer_orders = get_posts( array(
'numberposts' => -1,
'meta_key' => '_customer_user',
'meta_value' => $customer_id,
'post_type' => wc_get_order_types(),
'post_status' => array_keys( wc_get_order_statuses() ),
) );
if ( $customer_orders ){
foreach ( $customer_orders as $customer_order ) {
$order = wc_get_order();
$order_id = $order->id; // get the order ID )or may be "order->ID")
// getting all products items for each order
$items = $order->get_items();
foreach ($items as $item)
{
$product_id = $item['product_id']; // product id
$product_qty = $item['qty']; // product quantity
if(wc_customer_bought_product( $customer_email, $customer_id, $_product_id))
{
echo '<div>for order number: ' . $order_id . ' ,there is ' . $product_qty . ' for this product.';
}
}
}
}
}
参考文献: