我想在单个产品页面上使用双添加到购物车按钮。并希望在产品添加到购物车后重定向。
例如,在将继续按钮添加到购物车后,我想重定向到结帐页面。我想在添加到购物车后将添加并继续按钮重定向到另一个页面。
woocommerce_add_to_cart_redirect 使用此过滤器重定向时,两个按钮都重定向到同一页面。用 Jquery 试过。正确地它没有工作。请问有什么解决办法吗?
<?php
/**
* Simple product add to cart
*
* This template can be overridden by copying it to yourtheme/woocommerce/single-product/add-to-cart/simple.php.
*
* HOWEVER, on occasion WooCommerce will need to update template files and you
* (the theme developer) will need to copy the new files to your theme to
* maintain compatibility. We try to do this as little as possible, but it does
* happen. When this occurs the version of the template file will be bumped and
* the readme will list any important changes.
*
* @see https://docs.woocommerce.com/document/template-structure/
* @package WooCommerce\Templates
* @version 3.4.0
*/
defined( 'ABSPATH' ) || exit;
global $product;
if ( ! $product->is_purchasable() ) {
return;
}
echo wc_get_stock_html( $product ); // WPCS: XSS ok.
if ( $product->is_in_stock() ) : ?>
<?php do_action( 'woocommerce_before_add_to_cart_form' ); ?>
<form class="cart" action="<?php echo esc_url( apply_filters( 'woocommerce_add_to_cart_form_action', $product->get_permalink() ) ); ?>" method="post" enctype='multipart/form-data'>
<?php do_action( 'woocommerce_before_add_to_cart_button' ); ?>
<?php
do_action( 'woocommerce_before_add_to_cart_quantity' );
woocommerce_quantity_input(
array(
'min_value' => apply_filters( 'woocommerce_quantity_input_min', $product->get_min_purchase_quantity(), $product ),
'max_value' => apply_filters( 'woocommerce_quantity_input_max', $product->get_max_purchase_quantity(), $product ),
'input_value' => isset( $_POST['quantity'] ) ? wc_stock_amount( wp_unslash( $_POST['quantity'] ) ) : $product->get_min_purchase_quantity(), // WPCS: CSRF ok, input var ok.
)
);
do_action( 'woocommerce_after_add_to_cart_quantity' );
?>
<div class="double__cart">
<button type="submit" name="add-to-cart" value="<?php echo esc_attr( $product->get_id() ); ?>" class="single_add_to_cart_button button alt product_left_cart"><?php echo esc_html( 'Continue' ); ?></button>
<button type="submit" name="add-to-cart" value="<?php echo esc_attr( $product->get_id() ); ?>" class="single_add_to_cart_button button alt"><?php echo esc_html( $product->single_add_to_cart_text() ); ?></button>
</div>
<?php do_action( 'woocommerce_after_add_to_cart_button' ); ?>
</form>
<?php do_action( 'woocommerce_after_add_to_cart_form' ); ?>
<?php endif; ?>
这是两个按钮的代码。使用此代码,我在上面给出了电子商务简单产品添加到购物车按钮的所有代码。
<div class="double__cart">
<button type="submit" name="add-to-cart" value="<?php echo esc_attr( $product->get_id() ); ?>" class="single_add_to_cart_button button alt product_left_cart"><?php echo esc_html( 'Continue' ); ?></button>
<button type="submit" name="add-to-cart" value="<?php echo esc_attr( $product->get_id() ); ?>" class="single_add_to_cart_button button alt"><?php echo esc_html( $product->single_add_to_cart_text() ); ?></button>
</div>
它有效。但它只重定向到一页。如果我点击这两个按钮,它将被重定向到两个不同的页面。
function add_to_cart_redirect( $url ) {
$url = get_permalink( 30 );
return $url;}
add_filter( 'woocommerce_add_to_cart_redirect', 'add_to_cart_redirect' );
尝试使用 Jquery。正确地它没有工作。请问有什么解决办法吗?
$(".product_left_cart").click(function(){
if ( requiredVal !== '' ) {
var delay = 2000;
var url = '//abc.com'
setTimeout(function(){ window.location = url; }, delay);
}
});