Ad

Is There A Way I Can Make Woocommerce_loop_add_to_cart_link Not Change Url Address But Still Add Product To Cart?

Is there a way I can still add/remove a product to my cart without the page url changing?

I have custom add to cart button on my custom Wordpress theme but as I add product to cart the url changes to http://localhost/mytheme/?add-to-cart=15. Is there a way I can avoid it and still add product to the cart?

<?php global $product;

echo apply_filters( 'woocommerce_loop_add_to_cart_link',
    sprintf( '<a href="%s" rel="nofollow" data-product_id="%s" data-product_sku="%s" class="addtocart_nupp">Add product</a>',
        esc_url( $product->add_to_cart_url() ),
        esc_attr( $product->get_id() ),
        esc_attr( $product->get_sku() ),
        $product->is_purchasable() ? 'add_to_cart_button' : '',
        esc_attr( $product->get_type() ),
        esc_html( $product->add_to_cart_text() )
    ),
$product ); ?>
Ad

Answer

WooCommerce has a hook woocommerce_add_to_cart_redirect which is called when you add a product to your cart.

There are two arguments which you get $url where it is redirecting and $product which was added to your cart.

add_filter( 'woocommerce_add_to_cart_redirect', 'bks_add_to_cart_redirect', 10, 2 );
function bks_add_to_cart_redirect( $url, $product ) {
    if ( $product && is_a( $product, 'WC_Product' ) ) {
        // Do any change or URL you want to $url.
    }
    return $url;
}

You can change the logic and redirect it back to the product page by changing $url inside if like so.

$url = esc_url($product->get_permalink());

You can add paramters to it.

$url = esc_url( add_query_arg('name', 'value', $product->get_permalink() ) );

-- OR --

Just redirect it to a custom page.

$url = esc_url( home_url() . '/custom_page' );
Ad
source: stackoverflow.com
Ad