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        businessbloomer.com/woocommerce-customization
     * @author        Rodolfo Melogli, Business Bloomer
     * @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

    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 *