WooCommerce에서 Ajaxify 헤더 장바구니 항목 계산
챌린지
사용자 정의 WooCommerce 통합 WordPress 테마에서 항목 추가 후 장바구니 항목 수 표시기에 잘못된 값이 표시되는 문제가 발생했습니다. 범인은 장바구니에 특정 수량의 항목을 추가하여 표시기가 1씩만 증가하는 것이었습니다.
해결책
이 문제를 해결하기 위해 WooCommerce의 전용 기능을 활용할 수 있습니다. 장바구니 항목 수 업데이트를 위한 Ajax 지원을 제공하는 woocommerce_add_to_cart_fragments 액션 후크
구현
1. HTML 및 ID/클래스
테마의 header.php 파일에는 장바구니 개수를 표시할 HTML 요소를 정의합니다. 쉬운 타겟팅을 위해서는 고유한 ID나 클래스를 할당하는 것이 중요합니다.
<code class="html"><div id="mini-cart-count"><?php echo WC()->cart->get_cart_contents_count(); ?></div></code>
2. PHP 코드
다음으로, 후크를 사용하여 카트 개수 내용을 동적으로 업데이트하는 함수를 function.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 중국어 웹사이트의 기타 관련 기사를 참조하세요!