Home >Backend Development >PHP Tutorial >How to Refresh WooCommerce Header Cart Item Count Using Ajax?

How to Refresh WooCommerce Header Cart Item Count Using Ajax?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-11-01 01:45:28520browse

How to Refresh WooCommerce Header Cart Item Count Using Ajax?

Ajaxify Header Cart Items Count in WooCommerce

In WooCommerce, displaying the number of items in the cart in the header is essential for user navigation. When these items change (added or removed), it's desirable to update the cart count without reloading the page using JavaScript (specifically Ajax).

Getting the Cart Count from PHP Using Ajax

To obtain the current cart count from PHP using Ajax, we need to create a dedicated file, such as reloadCart.php, that echoes this count.

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

Next, in our JavaScript code, we can retrieve this count using the $.get() function:

<code class="js">$(".ajax_add_to_cart").click(function () {
    $.get("<?php echo get_template_directory_uri(); ?>/reloadCart.php", function(data){
        console.log("Cart Count: " + data);
    });
});</code>

However, using $.get() for this purpose is not the recommended approach in WooCommerce.

Utilizing the woocommerce_add_to_cart_fragments Action Hook

WooCommerce provides a dedicated woocommerce_add_to_cart_fragments action hook specifically designed for updating the cart content count in Ajax.

  1. Register the Action Hook:

    • In your theme's functions.php file, add the following code:
    <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>
  2. Update the HTML to Refresh:

    • In your header.php file, update the HTML that displays the cart count to use the mini-cart-count ID assigned in the above code:
    <code class="html"><div id="mini-cart-count"><?php echo WC()->cart->get_cart_contents_count(); ?></div></code>

Now, when the ajax_add_to_cart button is clicked, the woocommerce_add_to_cart_fragments action hook will automatically update the #mini-cart-count HTML element with the refreshed count.

Additional Information

  • The WC()->cart->get_cart_contents_count() method replaces the deprecated $woocommerce->cart->get_cart_contents_count().
  • To force refresh the count using jQuery, use the wc_fragment_refresh or wc_fragments_refreshed delegated events:

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

The above is the detailed content of How to Refresh WooCommerce Header Cart Item Count Using Ajax?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn