根据产品类型向产品价格添加自定义文本标签

问题描述 投票:0回答:2

我有一个小问题还无法解决。 我有这个 WooCommerce 网站,其中包含可变产品,目前价格以这种方式显示:

每打 5.50 美元 – 每打 100.00 美元

我使用这个 CSS 规则,在每个价格后添加“每打”,但这在当前情况下没有意义。

.price .amount:after {
content: " per dozen";
}

我想以这种方式显示该可变产品的价格:

5.50 美元每打 – 100.00 美元每箱(数量)

提前感谢您的帮助。

php wordpress woocommerce format product-price
2个回答
5
投票

在这里,您将能够根据需要使用挂钩在

woocommerce_price_html
woocommerce_variation_price_html
过滤器挂钩中的自定义函数添加自定义标签(适用于简单和变量产品。

对于变量产品中的最低/最高价格,我们需要一个挂钩在

woocommerce_variation_sale_price_html
过滤器挂钩中的独立函数。

更新:因为我的代码现在也将处理单个产品上的“每打”,您必须删除自定义 CSS 规则

.price .amount:after { content: " per dozen";}

这将避免到处都有重复的“每打”。

但是不可能根据所选属性值在实时价格上设置不同的标签。为此,唯一的方法是使用Javascript/jQuery,因为这是客户端的实时事件...

更新2
这是工作和测试的代码(请参阅最后的屏幕截图)

add_filter('woocommerce_variation_price_html','prices_custom_labels', 10, 2 );
add_filter('woocommerce_price_html','prices_custom_labels', 10, 2 );
function prices_custom_labels( $price, $product ){

    // Custom label name
    $per_dozen = ' '. __('per dozen', 'woocommerce' );

    // Set HERE your "quantity" attribute slug
    $attribute_qty_slug = 'pa_quantity';

    $attribute_qty_slug_key = 'attribute_'.$attribute_qty_slug;
    $append_label = '';

    // 1) Variable products
    if ($product->product_type != 'simple' && $product->variation_id ) {

        // Getting the attribute "quantity" value
        $attribute_qty_is_set = $product->variation_data[$attribute_qty_slug_key];

        // if "quantity" not set we display " per dozen"
        if( ! $attribute_qty_is_set )
            $append_label = $per_dozen;


        // Outputed price + custom label
        $price = '<ins class="highlight">'.woocommerce_price( $product->regular_price ).$append_label.'</ins>';
    }
    // 2) Simple products
    else
    {
        // Here the output price + custom default label
        $price = '<ins class="highlight">'.woocommerce_price( $product->regular_price ).$per_dozen.'</ins>';
    }
    return $price;
}

add_filter('woocommerce_variable_price_html', 'prices_custom_labels_min_max', 20, 2);
function prices_custom_labels_min_max( $price, $product) {

    // Custom label name
    $per_dozen = ' '. __('per dozen', 'woocommerce' );
    $per_case = ' '. __('per case', 'woocommerce' );

    // Set HERE your quantity attribute slug
    $attribute_qty_slug = 'pa_quantity';


    // Getting the min and max variations prices
    $variation_min_reg_price = $product->get_variation_regular_price('min', true);
    $variation_max_reg_price = $product->get_variation_regular_price('max', true);
    $variation_reg_price = $product->get_variation_regular_price();


    if( $variation_min_reg_price == $variation_max_reg_price )
    {
        $price = '<ins class="highlight">'.woocommerce_price($variation_reg_price) . $per_dozen . '</ins>';
    }
    else
    {
        if( !in_array( $attribute_qty_slug, array_keys( $product->get_attributes() ) ) )
        {
            $price = '<ins class="highlight">' . woocommerce_price($variation_min_reg_price) . $per_dozen . ' - ' . woocommerce_price($variation_max_reg_price) . $per_dozen . '</ins>';
        }
        else
        {
            $price = '<ins class="highlight">' . woocommerce_price($variation_min_reg_price) . $per_dozen . ' - ' . woocommerce_price($variation_max_reg_price) . $per_case . '</ins>';
        }
    }
    return $price;
}

代码位于活动子主题(或主题)的 function.php 文件中,或者也位于任何插件文件中


这是我的测试服务器的真实截图:

enter image description here

此代码经过测试并且确实有效。


相关解答:


0
投票

此代码解决了问题之一:

add_filter('woocommerce_variable_price_html',    'prices_custom_labels_min_max', 20, 2);
function prices_custom_labels_min_max( $price, $product) {

// Set HERE your custom labels names
$per_dozen = ' '. __('per dozen', 'woocommerce' );
$per_case = ' '. __('per case', 'woocommerce' );

// Getting the min and max variations prices
$variation_min_reg_price = $product->get_variation_regular_price('min',   true);
$variation_max_reg_price = $product->get_variation_regular_price('max',   true);

if( $variation_min_reg_price == $variation_max_reg_price ){
    $price = '<ins   class="highlight">'.woocommerce_price($variation_min_reg_price) . $per_dozen .    '</ins>';
}
else
{
    $price = '<ins class="highlight">' .   woocommerce_price($variation_min_reg_price) . $per_dozen . ' - ' .   woocommerce_price($variation_max_reg_price) . $per_case . '</ins>';
}
return $price;
}
© www.soinside.com 2019 - 2024. All rights reserved.