添加 ajax 以添加到购物车按钮并防止页面重新加载
Add ajax to add to cart buttons and prevent the page reload
我想知道如何改进下面的代码。它完全 100% 工作,但我想使用 ajax 以便我们可以防止页面在将产品添加到购物车后重新加载。
下面的代码添加了两个按钮,可以直接将 6 或 12 件商品添加到购物车。但是,如果我单击一个按钮,则页面会重新加载。如何使用 ajax 做得更好?
add_action( 'woocommerce_after_add_to_cart_button', 'additional_simple_add_to_cart', 20 );
function additional_simple_add_to_cart() {
global $product;
// Only for simple product type
if( ! $product->is_type('simple') ) return;
// Only for products from category "bier" AND/OR "Cider"
if ( has_term( array('bier', 'cider', 'getraenke'), 'product_cat', $product->get_id() ) ) {
// Open parent layout wrapper
echo '<div class="flex-container-pack-wrapper">';
// Open child left layout wrapper
echo '<div class="flex-container-pack-child left">';
// Only display when more than 6 are available
if( $product->get_stock_quantity() >= 6 ) {
$href = '?add-to-cart=' . esc_attr( $product->get_id() ) . '&quantity=6';
$class = 'single_add_to_cart_button-6 button alt';
$style = 'display: inline-block; margin-top: 12px;';
$button_text = __( "6er Pack", "woocommerce" );
// Output add to cart button
echo '<a rel="no-follow" href="'.$href.'" class="'.$class.'" style="'.$style.'">'.$button_text.'</a>';
}
else {
echo '<a class="single_sold_out_button button alt disabled ">6er Pack<p class="pack_soldout">(Ausverkauft)</p></a>';
}
// Close child left layout wrapper
echo '</div>';
// Open child right layout wrapper
echo '<div class="flex-container-pack-child right">';
// Only display when more than 12 are available
if( $product->get_stock_quantity() >= 12 ) {
$href = '?add-to-cart=' . esc_attr( $product->get_id() ) . '&quantity=12';
$class = 'single_add_to_cart_button-12 button alt';
$style = 'display: inline-block; margin-top: 12px;';
$button_text = __( "12er Pack", "woocommerce" );
// Output add to cart button
echo '<a rel="no-follow" href="'.$href.'" class="'.$class.'" style="'.$style.'">'.$button_text.'</a>';
}
else {
echo '<a class="single_sold_out_button button alt disabled ">12er Pack<p class="pack_soldout">(Ausverkauft)</p></a>';
}
// Close child right layout wrapper
echo '</div>';
// Close parent layout wrapper
echo '</div>';
// Open wrapper shipping info
echo '<div class="container_pack_wrapper_shipping_ino">';
// Output Info text for "bier" or "cider" products
//echo '<p class="shipping_info">Wähle 6, 9-12 oder 24 Biere einer Brauerei aus.</p>';
//echo '<p class="shipping_info_extra">*Spezial Angebote z.B Probierpakete sind von dieser Beschränkung ausgeschlossen.</p>';
// Tsting link to vendor
global $product;
$seller = get_post_field( 'post_author', $product->get_id());
$author = get_user_by( 'id', $seller );
$vendor = dokan()->vendor->get( $seller );
$store_info = dokan_get_store_info( $author->ID );
if ( !empty( $store_info['store_name'] ) ) {
// Output Info text for "bier" or "cider" products
echo '<p class="shipping_info">Wähle 6, 9-12 oder 24 Biere einer Brauerei aus.</p>';
// Output Vendor link
printf( '<i class="fas fa-angle-double-right pack"></i><a class="vendor_pack_info" href="%s">Mehr von %s</a>', $vendor->get_shop_url(), $vendor->get_shop_name() );
// Output shipping Info
echo '<p class="shipping_info_extra">*Spezial Angebote z.B Probierpakete sind von dieser Beschränkung ausgeschlossen. Versand wird je Brauerei berechnet.</p>';
}
// Close wrapper shipping info
echo '</div>';
}
}
在您的所有产品上,您已经拥有将商品添加到购物车的按钮,给它们一个 class(例如添加到购物车)并向其添加另一个属性 data-id。
<button type="button" class="add-to-cart" data-id="product-id">Add to Cart</button>
在您的 JS 中,您调用 button.add-to-cart class 的点击事件侦听器。使用 querySelector() 并获取单击按钮的数据 ID,将带有 ajax 调用的产品 ID 发送到您的 php 代码,在 ajax 的回调中(return ),
return 购物车中的商品数量:: 我建议购物车计数器(显示购物车中商品的数量)有一个 ID,您可以使用该 ID 更新 return添加到购物车 ajax 致电。
Woocommerce 提供 Ajax 添加到购物车功能
遵循这个方法
仪表板 >> woocommerce >> 设置 >> 产品 >> 检查(启用 AJAX 在存档上添加到购物车按钮)选项
<a href="?add-to-cart=420" data-quantity="1" class="button product_type_simple add_to_cart_button ajax_add_to_cart" data-product_id="420" data-product_sku="" aria-label="Add “Product Simple only” to your cart" rel="nofollow">Add to cart</a>
我想知道如何改进下面的代码。它完全 100% 工作,但我想使用 ajax 以便我们可以防止页面在将产品添加到购物车后重新加载。
下面的代码添加了两个按钮,可以直接将 6 或 12 件商品添加到购物车。但是,如果我单击一个按钮,则页面会重新加载。如何使用 ajax 做得更好?
add_action( 'woocommerce_after_add_to_cart_button', 'additional_simple_add_to_cart', 20 );
function additional_simple_add_to_cart() {
global $product;
// Only for simple product type
if( ! $product->is_type('simple') ) return;
// Only for products from category "bier" AND/OR "Cider"
if ( has_term( array('bier', 'cider', 'getraenke'), 'product_cat', $product->get_id() ) ) {
// Open parent layout wrapper
echo '<div class="flex-container-pack-wrapper">';
// Open child left layout wrapper
echo '<div class="flex-container-pack-child left">';
// Only display when more than 6 are available
if( $product->get_stock_quantity() >= 6 ) {
$href = '?add-to-cart=' . esc_attr( $product->get_id() ) . '&quantity=6';
$class = 'single_add_to_cart_button-6 button alt';
$style = 'display: inline-block; margin-top: 12px;';
$button_text = __( "6er Pack", "woocommerce" );
// Output add to cart button
echo '<a rel="no-follow" href="'.$href.'" class="'.$class.'" style="'.$style.'">'.$button_text.'</a>';
}
else {
echo '<a class="single_sold_out_button button alt disabled ">6er Pack<p class="pack_soldout">(Ausverkauft)</p></a>';
}
// Close child left layout wrapper
echo '</div>';
// Open child right layout wrapper
echo '<div class="flex-container-pack-child right">';
// Only display when more than 12 are available
if( $product->get_stock_quantity() >= 12 ) {
$href = '?add-to-cart=' . esc_attr( $product->get_id() ) . '&quantity=12';
$class = 'single_add_to_cart_button-12 button alt';
$style = 'display: inline-block; margin-top: 12px;';
$button_text = __( "12er Pack", "woocommerce" );
// Output add to cart button
echo '<a rel="no-follow" href="'.$href.'" class="'.$class.'" style="'.$style.'">'.$button_text.'</a>';
}
else {
echo '<a class="single_sold_out_button button alt disabled ">12er Pack<p class="pack_soldout">(Ausverkauft)</p></a>';
}
// Close child right layout wrapper
echo '</div>';
// Close parent layout wrapper
echo '</div>';
// Open wrapper shipping info
echo '<div class="container_pack_wrapper_shipping_ino">';
// Output Info text for "bier" or "cider" products
//echo '<p class="shipping_info">Wähle 6, 9-12 oder 24 Biere einer Brauerei aus.</p>';
//echo '<p class="shipping_info_extra">*Spezial Angebote z.B Probierpakete sind von dieser Beschränkung ausgeschlossen.</p>';
// Tsting link to vendor
global $product;
$seller = get_post_field( 'post_author', $product->get_id());
$author = get_user_by( 'id', $seller );
$vendor = dokan()->vendor->get( $seller );
$store_info = dokan_get_store_info( $author->ID );
if ( !empty( $store_info['store_name'] ) ) {
// Output Info text for "bier" or "cider" products
echo '<p class="shipping_info">Wähle 6, 9-12 oder 24 Biere einer Brauerei aus.</p>';
// Output Vendor link
printf( '<i class="fas fa-angle-double-right pack"></i><a class="vendor_pack_info" href="%s">Mehr von %s</a>', $vendor->get_shop_url(), $vendor->get_shop_name() );
// Output shipping Info
echo '<p class="shipping_info_extra">*Spezial Angebote z.B Probierpakete sind von dieser Beschränkung ausgeschlossen. Versand wird je Brauerei berechnet.</p>';
}
// Close wrapper shipping info
echo '</div>';
}
}
在您的所有产品上,您已经拥有将商品添加到购物车的按钮,给它们一个 class(例如添加到购物车)并向其添加另一个属性 data-id。
<button type="button" class="add-to-cart" data-id="product-id">Add to Cart</button>
在您的 JS 中,您调用 button.add-to-cart class 的点击事件侦听器。使用 querySelector() 并获取单击按钮的数据 ID,将带有 ajax 调用的产品 ID 发送到您的 php 代码,在 ajax 的回调中(return ), return 购物车中的商品数量:: 我建议购物车计数器(显示购物车中商品的数量)有一个 ID,您可以使用该 ID 更新 return添加到购物车 ajax 致电。
Woocommerce 提供 Ajax 添加到购物车功能
遵循这个方法
仪表板 >> woocommerce >> 设置 >> 产品 >> 检查(启用 AJAX 在存档上添加到购物车按钮)选项
<a href="?add-to-cart=420" data-quantity="1" class="button product_type_simple add_to_cart_button ajax_add_to_cart" data-product_id="420" data-product_sku="" aria-label="Add “Product Simple only” to your cart" rel="nofollow">Add to cart</a>