我正在使用最新的WC,我真的希望价格显示在每个变体旁边,以获得更好的概览.
我无法为我的functions.PHP找到合适的代码,以显示每个变体旁边的价格.我看到几个较旧的帖子,其中没有人真的有用.
我尝试了以下方法:
add_filter( 'woocommerce_variation_option_name', 'display_price_in_variation_option_name' );
function display_price_in_variation_option_name( $term ) {
global $wpdb, $product;
if ( empty( $term ) ) return $term;
if ( empty( $product->id ) ) return $term;
$result = $wpdb->get_col( "SELECT slug FROM {$wpdb->prefix}terms WHERE name = '$term'" );
$term_slug = ( !empty( $result ) ) ? $result[0] : $term;
$query = "SELECT postMeta.post_id AS product_id
FROM {$wpdb->prefix}postMeta AS postMeta
LEFT JOIN {$wpdb->prefix}posts AS products ON ( products.ID = postMeta.post_id )
WHERE postMeta.Meta_key LIKE 'attribute_%'
AND postMeta.Meta_value = '$term_slug'
AND products.post_parent = $product->id";
$variation_id = $wpdb->get_col( $query );
$parent = wp_get_post_parent_id( $variation_id[0] );
if ( $parent > 0 ) {
$_product = new WC_Product_Variation( $variation_id[0] );
return $term . ' (' . wp_kses( woocommerce_price( $_product->get_price() ), array() ) . ')';
}
return $term;
}
解决方法:
由于没有id参数woocommerce_variation_option_name,我们可以使用脚本执行此操作.
add_action( "wp_head", "function_to_woo_script" );
function function_to_woo_script () {
?>
<script>
$= jQuery;
$(document).ready(function(){
var json_product = jQuery.parseJSON( $(".variations_form").attr("data-product_variations") );
var currency = "$";
for( i = 0; i < json_product.length; i++ ) {
var attr_name = $(".variations select").attr("data-attribute_name");
$(".variations select option[value='"+json_product[i].attributes[attr_name]+"']").html( json_product[i].attributes[attr_name] + " - " + currency + json_product[i].display_regular_price );
}
});
</script>
<?PHP
}
结果
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。