我已经设法更改了成功消息上"查看购物车"按钮的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() 函数不会过滤掉它。