WooCommerce 中的 Ajaxify 标头购物车项目计数
挑战
在自定义 WooCommerce 集成中WordPress 主题出现了一个问题,即添加项目后购物车项目计数指示器显示不正确的值。罪魁祸首是向购物车添加了特定数量的商品,导致指标仅增加一。
解决方案
为了解决这个问题,我们可以利用 WooCommerce 的专用工具woocommerce_add_to_cart_fragments 操作挂钩,为更新购物车商品计数提供 Ajax 支持。
实现
1. HTML 和 ID/Class
在主题的 header.php 文件中,我们定义将显示购物车计数的 HTML 元素。分配唯一的 ID 或类别以便于定位非常重要:
<code class="html"><div id="mini-cart-count"><?php echo WC()->cart->get_cart_contents_count(); ?></div></code>
2. PHP代码
接下来,我们在functions.php文件中添加一个函数,使用钩子动态更新购物车计数内容:
<code class="php">add_filter( 'woocommerce_add_to_cart_fragments', 'wc_refresh_mini_cart_count'); function wc_refresh_mini_cart_count($fragments){ ob_start(); $items_count = WC()->cart->get_cart_contents_count(); ?> <div id="mini-cart-count"><?php echo $items_count ? $items_count : ' '; ?></div> <?php $fragments['#mini-cart-count'] = ob_get_clean(); return $fragments; }</code>
3. Ajax 更新
如果您需要使用 jQuery 进行额外控制,请考虑使用 wc_fragment_refresh 或 wc_fragments_refreshed 事件:
<code class="javascript">$(document.body).trigger('wc_fragment_refresh');</code>
或
<code class="javascript">$(document.body).trigger('wc_fragments_refreshed');</code>
通过实施这些更改,即使添加特定数量的产品,购物车商品计数指示器也会准确反映购物车中的商品数量。
以上是如何在 WooCommerce 中 Ajaxify 标头购物车项目计数?的详细内容。更多信息请关注PHP中文网其他相关文章!