WooCommerce根据wc_customer_bought_product函数获取订单中的产品数量

时间:2016-07-04 03:26:59

标签: php wordpress woocommerce product orders

我使用wc_customer_bought_product()功能检查当前用户是否购买了某种产品。

但是,现在我需要检查客户购买的该产品的数量

因此,例如,如果我在订单中购买了数量为7的产品,我需要一种方法来获得该产品的订单和订单数量。

我怎样才能做到这一点?

如果有人有答案,我将不胜感激。

1 个答案:

答案 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.';
                }

            }

        }

    }

}

参考文献: