>백엔드 개발 >PHP 튜토리얼 >AJAX를 사용하여 WooCommerce 헤더 장바구니 항목 수를 동적으로 업데이트하는 방법은 무엇입니까?

AJAX를 사용하여 WooCommerce 헤더 장바구니 항목 수를 동적으로 업데이트하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-29 06:19:021063검색

How to Dynamically Update WooCommerce Header Cart Items Count Using AJAX?

WooCommerce의 Ajaxify 헤더 카트 항목 수

필요성 식별

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

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