WooCommerce添加数据属性以查看成功消息上的购物车按钮



我已经设法更改了成功消息上"查看购物车"按钮的html标记,以便我可以向其添加id="open_cart",但是我还想在html输出中添加一个data-属性,例如data-cart="open",但是只返回id

关于如何向其添加data-属性的任何想法?

function my_add_to_cart_message() {
    if ( get_option( 'woocommerce_cart_redirect_after_add' ) == 'yes' ) :
    $message = sprintf( '%s<a id="open_cart" data-target="open-cart"  href="%s" class="button">%s</a>', __( 'Successfully added to cart.' , 'woocommerce' ), esc_url( get_permalink( woocommerce_get_page_id( 'cart' ) ) ), __( 'View Cart', 'woocommerce' ) );
    return $message;
}
add_filter( 'wc_add_to_cart_message', 'my_add_to_cart_message' );

这是上面的函数返回的内容:

<a id="open_cart" href="http://example.com/cart/" class="button wc-forward">Ver carrinho</a>

data-cart="open"将被忽略。简直烦人。

以下是关于为什么会发生这种情况的快速解释。

看看负责显示成功消息的Woocommerce成功.php模板。

<?php foreach ( $messages as $message ) : ?>
    <div class="woocommerce-message"><?php echo wp_kses_post( $message ); ?></div>
<?php endforeach; ?>

wp_kses_post() 函数通过检查允许的标记和属性来清理 $message 变量的输出。

以下是您的解决方案:

将此代码段添加到您的函数中.php

function my_filter_allowed_html($allowed, $context){
    if (is_array($context)) {
        return $allowed;
    }
    if ($context === 'post') { 
        $allowed['a']['data-cart'] = true;
    }
    return $allowed;
}
add_filter('wp_kses_allowed_html', 'my_filter_allowed_html', 10, 2);

您需要挂钩到wp_kses_allowed_html过滤器并添加您的数据属性,以便 wp_kses_post() 函数不会过滤掉它。

相关内容

最新更新