我在woocommerce中创建了一个可变产品,该产品具有3种产品变体。
我的问题是,每种产品变体的销售数量必须固定。
例如:
2红色,每个10,00€
3蓝色,每件12,00€
6绿色,每件16,00€
因此,客户必须订购3个红色或6个蓝色或12个绿色(不少于不少)。 我知道如何管理最小数量和最大数量,但是我不知道如何设置默认数量值。
任何帮助将不胜感激。
答案 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文件中。经过测试,可以正常工作。