首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >WooCommerce购物车数量按钮仅在重新加载后显示

WooCommerce购物车数量按钮仅在重新加载后显示
EN

Stack Overflow用户
提问于 2016-04-22 16:34:36
回答 2查看 1K关注 0票数 2

我已经在我的子主题中创建了购物车模板的副本,并对购物车行为进行了一些自定义更改(CSS side cart,就像在hibr.com中一样)。我的header.php中有以下与购物车相关的代码片段:

代码语言:javascript
复制
<div class="close-me2"></div>
<?php echo do_shortcode('[woocommerce_cart]'); ?>




<div class="cart-outer" data-user-set-ocm="<?php echo $userSetSideWidgetArea; ?>">
        <div class="cart-menu-wrap">
            <div class="cart-menu">
                <a class="cart-contents" href="<?php //echo $woocommerce->cart->get_cart_url(); ?>"><div class="cart-icon-wrap"><i class="icon-salient-cart"></i> <div class="cart-wrap"><span><?php echo $woocommerce->cart->cart_contents_count; ?> </span></div> </div></a>
            </div>
        </div>



<div id="side-cart">
<div class="close-me2"></div>
<?php echo do_shortcode('[woocommerce_cart]'); ?>

<?php if ( is_active_sidebar( 'sidebar-4' ) ) : ?>
    <div class="widget-area">
        <?php dynamic_sidebar( 'sidebar-4' ); ?>
    </div>
<?php endif; ?>

不幸的是,似乎每当向购物车添加产品时,都会显示“错误”购物车,因为没有显示数量按钮“-+”。刷新页面后,购物车显示数量按钮:http://screencast.com/t/gzkb6QPfz

我还安装了这个插件: wordpress.org/plugins/woocommerce-ajax-add-to-cart-for-variable-products/changelog/

这些是我添加到其中的自定义更改,因为我的侧推车需要被触发:

代码语言:javascript
复制
// Changes button classes
            $thisbutton.addClass( 'added' );

            var rightVal = 0; // base value
            $('#side-cart').animate({right: rightVal + 'px'}, {queue: false, duration: 500});

            $('.cart-outer a').attr("href", "javascript:void(0)");



            $('#side-cart .woocommerce').removeAttr('style');

            $('#side-cart .widget-area').removeAttr('style');


            $('.cart_empty3').attr('style', 'display:none !important;');

在我看来,在将产品添加到购物车后,一些脚本不能正确加载,但我不知道从哪里开始寻找bug。

如果你有什么想法,请告诉我。我会分享一个链接的网站,如果需要的话,因为我目前有http认证运行。

谢谢!

EN

回答 2

Stack Overflow用户

发布于 2016-04-23 20:55:23

我已经解决了覆盖quantity-input.php后的显示问题,如下所示:

代码语言:javascript
复制
<div class="quantity buttons_added">
<input type="button" value="-" class="minus">
	<input type="number" step="<?php echo esc_attr( $step ); ?>" min="<?php echo esc_attr( $min_value ); ?>" max="<?php echo esc_attr( $max_value ); ?>" name="<?php echo esc_attr( $input_name ); ?>" value="<?php echo esc_attr( $input_value ); ?>" title="<?php echo esc_attr_x( 'Qty', 'Product quantity input tooltip', 'woocommerce' ) ?>" class="input-text qty text" size="4" />
<input type="button" value="+" class="plus"></div>
</div>

并使用这个jquery来给qty按钮一个触发器:

代码语言:javascript
复制
jQuery(document).ready(function($){
    $('.quantity').on('click', '.plus', function(e) {
        $input = $(this).prev('input.qty');
        var val = parseInt($input.val());
        $input.val( val+1 ).change();
    });

    $('.quantity').on('click', '.minus', 
        function(e) {
        $input = $(this).next('input.qty');
        var val = parseInt($input.val());
        if (val > 0) {
            $input.val( val-1 ).change();
        } 
    });
});

但是现在的问题仍然是,在将产品添加到购物车后,只有在重新加载页面后才能点击数量按钮"+“和"-”。

在我看来,jquery没有正确加载。你对此有什么线索吗?还是我的jquery错了?

谢谢!

票数 0
EN

Stack Overflow用户

发布于 2016-04-24 14:39:14

更新:

我已经通过如下修改jQuery解决了这个问题:

代码语言:javascript
复制
jQuery(document).on('click', '.quantity .plus', function(e) {
    $input = jQuery(this).prev('input.qty');
    var val = parseInt($input.val());
    $input.val(val + 1).change();
}).on('click', '.quantity .minus', function(e) {
    $input = jQuery(this).next('input.qty');
    var val = parseInt($input.val());
    if(val > 0) {
        $input.val(val - 1).change();
    }
});

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36788871

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档