2 回答
TA贡献1851条经验 获得超4个赞
要显示可变产品变体中选定的产品价格,需要 jQuery。因此,以下短代码将处理所有产品类型,包括可变产品及其价格变化:
add_shortcode( 'product_price', 'display_formatted_product_price' );
function display_formatted_product_price( $atts ) {
extract(shortcode_atts( array(
'id' => null
), $atts, 'product_price' ) );
global $product;
if( ! empty($id) || ! is_a($product, 'WC_Product') ) {
$product = wc_get_product( empty($id) ? get_the_id() : $id );
}
$price_html = $product->get_price_html();
// Others product types than variable
if ( ! $product->is_type('variable') ) {
return '<span class="product-price">' . $price_html . '</span>';
}
// For variable products
else {
ob_start();
?>
<script type="text/javascript">
jQuery( function($){
var p = '<?php echo $price_html; ?>', s = 'span.product-price';
$( 'form.variations_form.cart' ).on('show_variation', function(event, data) {
$(s).html(data.price_html); // Display the selected variation price
});
$( 'form.variations_form.cart' ).on('hide_variation', function() {
$(s).html(p); // Display the variable product price range
});
});
</script>
<?php
return ob_get_clean() . '<span class="product-price">' . $price_html . '</span>';
}
}
代码位于活动子主题(或活动主题)的functions.php 文件中。经过测试并有效。
用途:
[product_price]在 php 代码中使用or echo do_shortcode('[product_price]')。
您还可以定义产品 ID,例如(例如产品 id 37):[product_price id="37"]
TA贡献1827条经验 获得超4个赞
我对一个问题很头疼:如果产品变体都具有相同的价格,则price_html将返回空(。我使用上面 github 转换中找到的过滤器解决了这个问题:
add_filter( 'woocommerce_show_variation_price', '__return_true');
- 2 回答
- 0 关注
- 90 浏览
添加回答
举报