Sha*_*ara 10 php wordpress product variations woocommerce
在WooCommerce上,我想更改Variable单一产品页面布局.因为,当您拥有可变产品时,您会在"变量产品"页面中获得此有线价格(在产品标题下方),并且它也会显示在商店页面中.
对我来说,标准方法是在商店和产品页面显示产品的最低价格,并根据用户选择的变量更改价格.我不敢相信为什么.
我可以使用此代码段删除价格范围并显示最低价格.
https://businessbloomer.com/disable-variable-product-price-range-woocommerce/
但话说回来,最低价格不会根据选择变量而改变.变量产品布局中还有两个价格.这是我当前的变量产品页面布局
http://www.preorders.lk/product/beats-solo3-wireless-on-ear-headphones/
因此,任何人都可以帮助从可变产品页面中删除价格范围,并仅显示产品的最低价格(在产品标题下)作为默认值.因此,价格应根据产品的变量而变化.并且最低价格也应该在商店页面中显示.
希望这很清楚.如果有任何不清楚的地方,请告诉我.有关更多详细信息,请参阅附图.
谢谢.
Loi*_*tec 14
以下主题中的新改进更新(2018年6月):
更新(2017年12月):避免,某些主题中关于非变量产品的问题以及某些主题中的重复可用性错误
注意:像德国市场或某些主题这样的插件不适用于此代码,因为它们在钩子或html结构中进行自己的更改.
这是完全可能的.
jQuery脚本的帮助下,当我们获得所选的变化价格时,我们将替换可变价格(并显示库存可用性).这是代码:
add_action( 'woocommerce_before_single_product', 'move_variations_single_price', 1 );
function move_variations_single_price(){
global $product, $post;
if ( $product->is_type( 'variable' ) ) {
// removing the variations price for variable products
remove_action( 'woocommerce_single_product_summary', 'woocommerce_template_single_price', 10 );
// Change location and inserting back the variations price
add_action( 'woocommerce_single_product_summary', 'replace_variation_single_price', 10 );
}
}
function replace_variation_single_price(){
global $product;
// Main Price
$prices = array( $product->get_variation_price( 'min', true ), $product->get_variation_price( 'max', true ) );
$price = $prices[0] !== $prices[1] ? sprintf( __( 'From: %1$s', 'woocommerce' ), wc_price( $prices[0] ) ) : wc_price( $prices[0] );
// Sale Price
$prices = array( $product->get_variation_regular_price( 'min', true ), $product->get_variation_regular_price( 'max', true ) );
sort( $prices );
$saleprice = $prices[0] !== $prices[1] ? sprintf( __( 'From: %1$s', 'woocommerce' ), wc_price( $prices[0] ) ) : wc_price( $prices[0] );
if ( $price !== $saleprice && $product->is_on_sale() ) {
$price = '<del>' . $saleprice . $product->get_price_suffix() . '</del> <ins>' . $price . $product->get_price_suffix() . '</ins>';
}
?>
<style>
div.woocommerce-variation-price,
div.woocommerce-variation-availability,
div.hidden-variable-price {
height: 0px !important;
overflow:hidden;
position:relative;
line-height: 0px !important;
font-size: 0% !important;
}
</style>
<script>
jQuery(document).ready(function($) {
$('select').blur( function(){
if( '' != $('input.variation_id').val() ){
if($('p.availability'))
$('p.availability').remove();
$('p.price').html($('div.woocommerce-variation-price > span.price').html()).append('<p class="availability">'+$('div.woocommerce-variation-availability').html()+'</p>');
console.log($('input.variation_id').val());
} else {
$('p.price').html($('div.hidden-variable-price').html());
if($('p.availability'))
$('p.availability').remove();
console.log('NULL');
}
});
});
</script>
<?php
echo '<p class="price">'.$price.'</p>
<div class="hidden-variable-price" >'.$price.'</div>';
}
Run Code Online (Sandbox Code Playgroud)
代码进入您的活动子主题(或主题)的任何php文件或任何插件php文件.
此代码经过测试并适用于WooCommerce 3.2.x (也适用于WooCommerce 2.6.x)
您可以选择将CSS (
<style></style>)移动到styles.css活动子主题(或活动主题)的文件中,然后将其从此函数中删除...
有关:
Luu*_*eur 10
聚会迟到了,但我正在寻找更动态/通用的解决方案和更少的代码,因此我将答案调整为以下内容。
价格根据变体形式触发器更新,因此样式和原始 HTML 得以保留。
add_action( 'woocommerce_before_single_product', 'move_variations_single_price', 1 );
function move_variations_single_price(){
global $product, $post;
if ( $product->is_type( 'variable' ) ) {
add_action( 'woocommerce_single_product_summary', 'replace_variation_single_price', 10 );
}
}
function replace_variation_single_price() {
?>
<style>
.woocommerce-variation-price {
display: none;
}
</style>
<script>
jQuery(document).ready(function($) {
var priceselector = '.product p.price';
var originalprice = $(priceselector).html();
$( document ).on('show_variation', function() {
$(priceselector).html($('.single_variation .woocommerce-variation-price').html());
});
$( document ).on('hide_variation', function() {
$(priceselector).html(originalprice);
});
});
</script>
<?php
}
Run Code Online (Sandbox Code Playgroud)
使用 v4.0.1 成功测试。只要主题/插件不更改标记,它就应该可以工作。如果没有,您可以轻松地priceselector相应地更改。
| 归档时间: |
|
| 查看次数: |
15115 次 |
| 最近记录: |