为Woocommerce中的产品变化设置不同的输入数量值

时间:2018-11-24 01:22:48

标签: php jquery wordpress woocommerce variations

我在woocommerce中创建了一个可变产品,该产品具有3种产品变体。

我的问题是,每种产品变体的销售数量必须固定。

例如:
2红色,每个10,00€
3蓝色,每件12,00€
6绿色,每件16,00€

因此,客户必须订购3个红色或6个蓝色或12个绿色(不少于不少)。 我知道如何管理最小数量和最大数量,但是我不知道如何设置默认数量值。

任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:0)

在以下两个功能中,您需要首先设置父变量产品ID,并在第一个功能上为每个变量ID设置相应的固定数量。

要根据每个选定的变化动态设置输入数量,唯一的方法是使用Javascript(Jquery)。这是在第二个功能中完成的。

代码:

add_filter( 'woocommerce_available_variation', 'custom_variation_min_max_qty', 10, 3 );
function custom_variation_min_max_qty( $data, $product, $variation ) {
    // Your variable product ID
    $variable_id = 73;

    if( $product->get_id() == $variable_id ) {
        // Set 1st variation ID
        if( $variation->get_id() == 1015 ){
            $qty = 3; // Set the quantity
        } 
        // Set 2nd variation ID
        elseif( $variation->get_id() == 1014 ){
            $qty = 6; // Set the quantity
        }
        // Set 3rd variation ID
        elseif( $variation->get_id() == 1013 ){
            $qty = 12; // Set the quantity
        }
    }

    if( isset($qty) ) {
        $data['min_qty'] = $qty;
        $data['max_qty'] = $qty;
    }

    return $data;
}

add_action( 'woocommerce_after_single_variation',  'change_variation_input_quantity_script' );
function change_variation_input_quantity_script() {
    global $product;

    // Your variable product ID
    $variable_id = 73;

    if( $product->get_id() != $variable_id ) return;

    // Output Javascript
    ?>
    <!-- JS Thankyou Script -->
    <script type="text/javascript">
    jQuery(function($) {
        var a = 'div.quantity > input.qty';
        // On load
        setTimeout(function(){
            $(a).val($(a).prop('min'));
        }, 300);

        // On change / select a variation
        $('.variations_form select').on( 'blur', function(){
            if( $('input[name="variation_id"]').val() > 0 )
                $(a).val($(a).prop('min'));
        })

    });
    </script>
    <?php
}

代码进入您的活动子主题(或活动主题)的function.php文件中。经过测试,可以正常工作。


可以根据特定的产品属性值自动执行正确的变化检测...

就像您的示例一样,可以定位变体的“颜色”产品属性值。您需要在函数中定义“颜色”产品属性分类法,该分类法为 pa_color

因此,您将第一个函数替换为:

add_filter( 'woocommerce_available_variation', 'custom_variation_min_max_qty', 10, 3 );
function custom_variation_min_max_qty( $data, $product, $variation ) {
    // Your variable product ID
    $variable_id = 73;

    if( $product->get_id() == $variable_id ) {
        // Define your product attribute (always start with "pa_" + the slug)
        $taxonomy = 'pa_color';

        foreach($data['attributes'] as $attribute => $value_slug ){
            if( $attribute == 'attribute_' . $taxonomy ) {
                // set your color slugs below with the correct quantity
                if ( $value_slug == 'red' ) 
                {
                    $qty = 3; // Set the quantity for "Red" color
                    break;
                }
                elseif ( $value_slug == 'blue' )
                {
                    $qty = 6; // Set the quantity for "Blue" color
                    break;
                }
                elseif ( $value_slug == 'green' )
                {
                    $qty = 12; // Set the quantity for "Green" color
                    break;
                }
            }
        }
    }

    if( isset($qty) ) {
        $data['min_qty'] = $qty;
        $data['max_qty'] = $qty;
    }

    return $data;
}

您将保持第二个功能不变。

代码进入您的活动子主题(或活动主题)的function.php文件中。经过测试,可以正常工作。