我试图为functions.php文件制作一个代码段,只显示所选变体的一个价格,从而忽略单个产品页面上显示的价格范围以及变化价格。我使用以下代码:
add_action( 'woocommerce_before_single_product', 'my_remove_variation_price' );
$product_variations=$product_variable->get_available_variations;
function my_remove_variation_price() {
global $product;
if ( $product->is_type( 'variable' ) {
remove_action( 'woocommerce_single_product_summary', 'woocommerce_template_single_price' );
}
}
问题在于,例如,当您有两种不同的单品和一种缺货时,此脚本会隐藏单个产品页面上剩余的一个变体的价格。 我想也许每个产品可以有COUNT个可用的变体,并使用IF来使用标准的单个产品模板显示它们。或者你可能更清楚如何解决这个问题?
答案 0 :(得分:2)
获得"库存"您可以在单个产品页面上更改可变产品的数量:
1)仅使用php和Woocommerce WC_Product方法:
global $product;
$count_in_stock = 0;
if ( $product->is_type( 'variable' ) ) {
$variation_ids = $product->get_children(); // Get product variation IDs
foreach( $variation_ids as $variation_id ){
$variation = wc_get_product($variation_id);
if( $variation->is_in_stock() )
$count_in_stock++;
}
}
// Your condition
if( $count_in_stock <= 1 ){
// Do something
}
2)使用几乎没有php(快速和轻量级)的SQL查询:
global $wpdb, $product;
$product_id = $product->get_id();
$count_in_stock = 0;
if ( $product->is_type( 'variable' ) ) {
$count = $wpdb->get_col("
SELECT count(p.ID) as in_stock_count FROM {$wpdb->prefix}postmeta as pm
INNER JOIN {$wpdb->prefix}posts as p ON pm.post_id = p.ID
WHERE p.post_type LIKE 'product_variation' AND p.post_parent = $product_id
AND pm.meta_key LIKE '_stock_status' AND pm.meta_value LIKE 'instock'
");
$count_in_stock = reset($count);
}
// Your condition
if( $count_in_stock <= 1 ){
// Do something
}
这两个代码都经过测试和工作。
答案 1 :(得分:1)
这是我的最终工作代码,在LoicTheAztec答案的帮助下实现:
add_action( 'woocommerce_before_single_product', 'my_remove_variation_price' );
function my_remove_variation_price() {
global $product;
$count_in_stock = 0;
if ( $product->is_type( 'variable' )) {
$variation_ids = $product->get_children(); // Get product variation IDs
foreach( $variation_ids as $variation_id ){
$variation = wc_get_product($variation_id);
if( $variation->is_in_stock() )
$count_in_stock++;
}
}
if( $count_in_stock <= 1 )
{
remove_action( 'woocommerce_single_product_summary', 'woocommerce_template_single_price' );
}
}