Heim >Backend-Entwicklung >PHP-Tutorial >Wie aktualisiere ich die Anzahl der Artikel im WooCommerce-Header-Warenkorb mithilfe von AJAX dynamisch?

Wie aktualisiere ich die Anzahl der Artikel im WooCommerce-Header-Warenkorb mithilfe von AJAX dynamisch?

Linda Hamilton
Linda HamiltonOriginal
2024-10-29 06:19:021060Durchsuche

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

Anzahl der Ajaxify-Header-Warenkorbelemente in WooCommerce

Identifizierung des Bedarfs

In WooCommerce integrierte WordPress-Themes, Aktualisierung des Header-Warenkorbs Elemente zu zählen, ohne die Seite neu zu laden, ist eine häufige Herausforderung. jQuery bietet eine Lösung, es stellen sich jedoch Fragen, wenn Artikel in mehreren Mengen hinzugefügt werden können.

Verwendung von AJAX zum Abrufen der Gesamtzahl

Um die Gesamtzahl des Warenkorbs dynamisch aus PHP abzurufen Sitzungen mit jQuery wird eine reloadCart.php-Datei erstellt, um den Wert wiederzugeben:

<code class="php"><?php
require('../../../wp-blog-header.php');
global $woocommerce;
echo $woocommerce->cart->get_cart_contents_count();
?></code>

AJAX-Implementierung

Es wird jedoch versucht, AJAX-Aufrufe an diese Datei mit durchzuführen Die Funktionen get(), post() oder ajax() von jQuery waren nicht erfolgreich.

Verbesserter Ansatz

Anstatt sich auf ein Neuladen zu verlassen, bietet WooCommerce ein spezielles woocommerce_add_to_cart_fragments an Aktions-Hook, der Ajax unterstützt.

HTML-Integration

Einbetten der Warenkorbanzahl in den Header mit einer eindeutigen ID oder Klasse:

<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-Code

Implementieren Sie den folgenden Code in der function.php-Datei des Themes oder einem Plugin:

<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>

Ersetzen Sie #mini-cart-count durch .mini-cart- zählen, wenn eine Klasse verwendet wird.

jQuery-Aktualisierung

Wenn eine zusätzliche jQuery-Aktualisierung erforderlich ist:

<code class="php">$(document.body).trigger('wc_fragment_refresh');</code>

oder

<code class="php">$(document.body).trigger('wc_fragments_refreshed');</code>

Das obige ist der detaillierte Inhalt vonWie aktualisiere ich die Anzahl der Artikel im WooCommerce-Header-Warenkorb mithilfe von AJAX dynamisch?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn