我使用了一个函数来自动标记所有产品,而不必使用SQL或手动执行它,因为它们经常重新上载和更新。
除了has_term if语句之外,该函数的工作方式也很完美。它们在Wordpress后端工作,并在我添加标签后立即应用定价规则,但是当我尝试将产品添加到购物车时,它会恢复到购物车和结帐页面中的原始价格。如果我删除if语句它没有问题。我需要一种方法让该功能仅适用于标记为“ama”的产品。
// Simple, grouped and external products
add_filter('woocommerce_product_get_price', 'custom_price', 90, 2 );
add_filter('woocommerce_product_get_regular_price', 'custom_price', 90, 2 );
// Product variations (of a variable product)
add_filter('woocommerce_product_variation_get_regular_price', 'custom_price', 99, 2 );
add_filter('woocommerce_product_variation_get_price', 'custom_price', 90, 2 );
// Variable product price range
add_filter('woocommerce_variation_prices_price', 'custom_variation_price', 90, 3 );
add_filter('woocommerce_variation_prices_regular_price', 'custom_variation_price', 90, 3 );
function custom_price( $price, $product ) {
if ( has_term( 'ama', 'product_tag' ) ) {
if ($price > 0.01 && $price < 4.99) {
$price *= 2.5;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 5 && $price < 9.99) {
$price *= 2;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 10 && $price < 19.99) {
$price *= 1.75;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 20 && $price < 39.99) {
$price *= 1.5;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 40 && $price < 59.99) {
$price *= 1.35;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 60 && $price < 79.99) {
$price *= 1.25;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 80 && $price < 999.99) {
$price *= 1.20;
$price = ceil($price + 0.01) - 0.01;
}
}
return $price;
}
function custom_variation_price( $price, $variation, $product ) {
if ( has_term( 'ama', 'product_tag' ) ) {
if ($price > 0.01 && $price < 4.99) {
$price *= 2.5;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 5 && $price < 9.99) {
$price *= 2;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 10 && $price < 19.99) {
$price *= 1.75;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 20 && $price < 39.99) {
$price *= 1.5;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 40 && $price < 59.99) {
$price *= 1.35;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 60 && $price < 79.99) {
$price *= 1.25;
$price = ceil($price + 0.01) - 0.01;
}
elseif ($price > 80 && $price < 999.99) {
$price *= 1.20;
$price = ceil($price + 0.01) - 0.01;
}
}
return $price;
}
答案 0 :(得分:2)
我重新访问了您的代码......我已将定价更新合并到一个单独的实用程序函数中......
为避免您的问题,需要定义产品ID (之前检查产品类型)。
然后我们在WordPress has_term()条件函数中设置这个正确定义的产品ID。
现在您的价格也适用于购物车和结帐页面......
您重新访问的代码:
// Utility pricing function
function filtering_product_prices( $price, $product ) {
// Get the product ID
$product_id = $product->is_type('variation') ? $product->get_parent_id() : $product->get_id();
// Only for Woocomerce Product Tag "ama"
if ( ! has_term( 'ama', 'product_tag', $product_id ) ) return $price; // Exit
if ( $price < 5 ) {
$price *= 2.5;
} elseif ( $price >= 5 && $price < 10 ) {
$price *= 2;
} elseif ( $price >= 10 && $price < 20 ) {
$price *= 1.75;
} elseif ( $price >= 20 && $price < 40 ) {
$price *= 1.5;
} elseif ( $price >= 40 && $price < 60 ) {
$price *= 1.35;
} elseif ( $price >= 60 && $price < 80 ) {
$price *= 1.25;
} elseif ( $price >= 80 && $price < 1000 ) {
$price *= 1.20;
}
return ceil($price + 0.01) - 0.01;
}
// Simple, grouped and external products
add_filter('woocommerce_product_get_price', 'custom_price', 90, 2 );
add_filter('woocommerce_product_get_regular_price', 'custom_price', 90, 2 );
// Product variations (of a variable product)
add_filter('woocommerce_product_variation_get_regular_price', 'custom_price', 99, 2 );
add_filter('woocommerce_product_variation_get_price', 'custom_price', 90, 2 );
function custom_variation_price( $price, $variation, $product ) {
return filtering_product_prices( $price, $product );
}
// Variable product price range
add_filter('woocommerce_variation_prices_price', 'custom_variation_price', 90, 3 );
add_filter('woocommerce_variation_prices_regular_price', 'custom_variation_price', 90, 3 );
function custom_price( $price, $product ) {
return filtering_product_prices( $price, $product );
}
代码放在活动子主题(或活动主题)的function.php文件中。经过测试和工作。