Redirect to Checkout after Adding Product to Cart

In this tutorial I will show you how to make WooCommerce “Add to cart” buttons to perform a redirect to the checkout page. And yes, we’re also going to change the button text.

It can be done in 4 simple steps. Let’s go!

1. Disable AJAX add to cart buttons

First of all we have to do some small configurations in WooCommerce Settings – Uncheck the “Enable AJAX add to cart buttons on archives” checkbox. That’s all.

WooCommerce Product Settings – Disable AJAX for add to cart buttons.
Go to WooCommerce > Settings > Products and uncheck “Enable AJAX add to cart…”

Once done, let’s continue to the code part.

2. Change text on add to cart buttons

If you’re not sure where to insert the code – the best way is your custom plugin, if you do not know how to create one, then use your child theme functions.php file, and the last option is your current theme functions.php, which is not recommended if your theme receives updates periodically.

/*
 * Change button text on Product Archives
 */
add_filter( 'woocommerce_loop_add_to_cart_link', 'misha_add_to_cart_text_1' );

function misha_add_to_cart_text_1( $add_to_cart_html ) {
	return str_replace( 'Add to cart', 'Buy now', $add_to_cart_html );
}

/*
 * Change button text on product pages
 */
add_filter( 'woocommerce_product_single_add_to_cart_text', 'misha_add_to_cart_text_2' );

function misha_add_to_cart_text_2( $product ){
	return 'Buy now';
}

I decided that str_replace() for this situation is the most simple and easy solution, but if you do not want to use it, you can replace the first part of the code with this one:

/*
 * Change button text on Product Archives
 */
add_filter( 'woocommerce_product_add_to_cart_text', 'misha_add_to_cart_text_1', 10, 2 );
 
function misha_add_to_cart_text_1( $text, $product ){
	return $product->is_purchasable() && $product->is_in_stock() ? 'Buy Now' : 'Read more';
}

3. Redirect to Checkout Page

The main piece of code is here 🚀 I’ve seen many tutorials where just this piece of code is provided, but it is not enough of course.

/**
 * Redirect to Checkout Page after Add to Cart @ WooCommerce
 */
add_filter( 'woocommerce_add_to_cart_redirect', 'misha_skip_cart_redirect_checkout' );
 
function misha_skip_cart_redirect_checkout( $url ) {
	return wc_get_checkout_url();
}

Function wc_get_checkout_url() returns the current URL of your checkout page. I know, you can obtain your checkout page URL directly with the help of get_permalink() and get_option() functions. The checkout page ID is stored in wp_options under woocommerce_checkout_page_id key by the way.

But I recommend to use wc_get_checkout_url() in any way.

Fix for “Sold Individually” Products

I noticed one bug so. If your product is configured to be sold individually, like this:

WooCommerce Product Settings – Sold Individually Checkbox

Then, when you’re trying to add this product to the cart and it is already in the cart, your will receive this error message:

WooCommerce Cart Error – Can not add another product which is supposed to be sold individually to the cart.

Certainly we do not want this message do be shown, do we?

My recommendation is simple – hook the add to cart url with woocommerce_product_add_to_cart_url, check if the product is already in the cart and if so, replace the add to cart url with the checkout url. Easy peasy 🙃

add_filter( 'woocommerce_product_add_to_cart_url', 'misha_fix_for_individual_products', 10, 2 );
function misha_fix_for_individual_products( $add_to_cart_url, $product ){
 
	if( $product->get_sold_individually() // if individual product
	&& WC()->cart->find_product_in_cart( WC()->cart->generate_cart_id( $product->id ) ) // if in the cart
	&& $product->is_purchasable() // we also need these two conditions
	&& $product->is_in_stock() ) {
		$add_to_cart_url = wc_get_checkout_url();
	}
 
	return $add_to_cart_url;
 
}

4. Remove “The product has been added to your cart” message

Almost done, but…

WooCommerce how to remove added to your cart message.

Do not you think this message looks weird in our case? Let’s remove it with the code below

add_filter( 'wc_add_to_cart_message_html', 'misha_remove_add_to_cart_message' );
 
function misha_remove_add_to_cart_message( $message ){
	return '';
}

That’s the complete solution. If the code doesn’t work for you or you have some questions, ask in comments below 👇

Misha Rudrastyh

Misha Rudrastyh

Hey guys and welcome to my website. For more than 10 years I've been doing my best to share with you some superb WordPress guides and tips for free.

Need some developer help? Contact me

Follow me on X