WooCommerce: Custom “Empty Cart” Button

A dedicated “Empty Cart” button can significantly streamline the customer journey on your WooCommerce website.

Yes, you can manually change the product quantities to 0 on the cart page, or click on the “remove item” icon for each product… but having a button that can do all that could be a time saver, especially for B2B WooCommerce customers.

This post will guide you through creating a custom empty cart button. We’ll cover a code-based solution that uses jQuery to listen to button clicks and Ajax to trigger the empty cart function.

Enjoy!

PHP Snippet: Empty WooCommerce Cart Upon Custom Button Click

A note before you copy and paste the code below.

I use the “woocommerce_proceed_to_checkout” hook to echo a button above the “Proceed to Checkout” button. This works for the Classic Cart but not the Cart Block.

In case you use the Cart Block, remove the button echo as per the snippet comment below, and try using “wp_footer” instead of “woocommerce_proceed_to_checkout“. Or use the Cart Block visual hook guide to achieve something similar without adding a button by hand.

    /**
     * @snippet       Custom WooCommerce Empty Cart Button
     * @how-to        Get CustomizeWoo.com FREE
     * @author        Rodolfo Melogli
     * @testedwith    WooCommerce 9
     * @community     https://businessbloomer.com/club/
     */
    
    add_action( 'woocommerce_proceed_to_checkout', 'bbloomer_empty_cart_button_and_listener', 21 );
    
    function bbloomer_empty_cart_button_and_listener() {
    
       // IF YOU ARE USING THE CART BLOCK, REMOVE THE FOLLOWING LINE
       // AND ADD A BUTTON WITH THE "empty-button" CLASS INSTEAD
    	echo '<a role="button" class="empty-button">Empty Cart</a>';
    
    	wc_enqueue_js( "
    		$('.empty-button').click(function(e){
            	e.preventDefault();
               	$.post( '" . '/wp-admin/admin-ajax.php' . "', { action: 'empty_cart' }, function() {
    				location.reload();
    			});
            });
    	" );
    }
    
    add_action( 'wp_ajax_empty_cart', 'bbloomer_empty_cart' );
    add_action( 'wp_ajax_nopriv_empty_cart', 'bbloomer_empty_cart' );
     
    function bbloomer_empty_cart() {	
        WC()->cart->empty_cart();
    }
    

    Where to add custom code?

    You should place custom PHP in functions.php and custom CSS in style.css of your child theme: where to place WooCommerce customization?

    This code still works, unless you report otherwise. To exclude conflicts, temporarily switch to the Storefront theme, disable all plugins except WooCommerce, and test the snippet again: WooCommerce troubleshooting 101

    Related content

    • WooCommerce: How to Fix the “Cart is Empty” Issue
      For some reason, sometimes you add products to cart but the cart page stays empty (even if you can clearly see the cart widget has products in it for example). But don’t worry – it may just be a simple cache issue (and if you don’t know what cache is that’s no problem either) or […]
    • WooCommerce: Remaining $$$ to Get Free Shipping Notification @ Cart
      This is a very cool snippet that many of you should use to increase your average order value. Ecommerce customers who are near the “free shipping” threshold will try to add more products to the cart in order to qualify for free shipping. It’s pure psychology. So, here’s how we show a simple message on […]
    • WooCommerce: Cart and Checkout on the Same Page
      This is your ultimate guide – complete with shortcodes, snippets and workarounds – to completely skip the Cart page and have both cart table and checkout form on the same (Checkout) page. But first… why’d you want to do this? Well, if you sell high ticket products (i.e. on average, you sell no more than […]
    • WooCommerce: Weight-Based Shipping Methods
      With WooCommerce you get 3 default shipping methods: Flat Rate, Free Shipping, Local Pickup. For each one you can define a cost, however there is no way to set up some “weight” restrictions. So, what if you want to display a rate for orders below 10 kg, and another shipping rate for orders above that […]
    • WooCommerce: Hide Shipping Method If Shipping Class Is In The Cart
      Our goal is to check if a Product with a specific Shipping Class is in the Cart, and consequently disabling a shipping rate such as Free Shipping if this is true. This is super useful when there are multiple items in the cart and you don’t want to give free shipping for certain orders for […]

    Rodolfo Melogli

    Business Bloomer Founder

    Author, WooCommerce expert and WordCamp speaker, Rodolfo has worked as an independent WooCommerce freelancer since 2011. His goal is to help entrepreneurs and developers overcome their WooCommerce nightmares. Rodolfo loves travelling, chasing tennis & soccer balls and, of course, wood fired oven pizza. Follow @rmelogli

    Questions? Feedback? Customization? Leave your comment now!
    _____

    If you are writing code, please wrap it like so: [php]code_here[/php]. Failure to complying with this, as well as going off topic or not using the English language will result in comment disapproval. You should expect a reply in about 2 weeks - this is a popular blog but I need to get paid work done first. Please consider joining the Business Bloomer Club to get quick WooCommerce support. Thank you!

    Your email address will not be published. Required fields are marked *