필요성 식별
WooCommerce 통합 WordPress 테마에서 헤더 카트 업데이트 페이지를 다시 로드하지 않고 항목 수를 계산하는 것은 일반적인 문제입니다. jQuery는 솔루션을 제공하지만 항목을 여러 수량으로 추가할 수 있는 경우 질문이 발생합니다.
AJAX를 활용하여 총 개수 검색
PHP에서 총 장바구니 개수를 동적으로 검색하려면 jQuery를 사용하는 세션에서는 다음 값을 반영하기 위해 reloadCart.php 파일이 생성됩니다.
<code class="php"><?php require('../../../wp-blog-header.php'); global $woocommerce; echo $woocommerce->cart->get_cart_contents_count(); ?></code>
AJAX 구현
그러나 다음을 사용하여 이 파일에 대한 AJAX 호출을 시도합니다. jQuery의 get(), post() 또는 ajax() 함수가 실패했습니다.
향상된 접근 방식
WooCommerce는 다시 로드에 의존하는 대신 전용 woocommerce_add_to_cart_fragments를 제공합니다. Ajax를 지원하는 액션 후크
HTML 통합
고유 ID 또는 클래스를 사용하여 헤더에 카트 수를 포함합니다.
<code class="php">$items_count = WC()->cart->get_cart_contents_count(); ?> <div id="mini-cart-count"><?php echo $items_count ? $items_count : '&nbsp;'; ?></div> <?php
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 : '&nbsp;'; ?></div> <?php $fragments['#mini-cart-count'] = ob_get_clean(); return $fragments; }</code>
#mini-cart-count를 .mini-cart-로 바꾸세요. 클래스를 사용하는 경우 계산합니다.
jQuery 새로 고침
추가 jQuery 새로 고침이 필요한 경우:
<code class="php">$(document.body).trigger('wc_fragment_refresh');</code>
또는
<code class="php">$(document.body).trigger('wc_fragments_refreshed');</code>
위 내용은 AJAX를 사용하여 WooCommerce 헤더 장바구니 항목 수를 동적으로 업데이트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!