>백엔드 개발 >PHP 튜토리얼 >WooCommerce에서 헤더 장바구니 항목 수를 Ajaxify하는 방법은 무엇입니까?

WooCommerce에서 헤더 장바구니 항목 수를 Ajaxify하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-30 01:26:02889검색

How to Ajaxify Header Cart Items Count in WooCommerce?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.