Jquery,什么是分离两个干扰函数并将变量相互传递的最佳方法?

时间:2017-06-23 06:55:51

标签: javascript jquery ajax simplecart

我意识到这可能已经以某种方式得到了解答,我将继续努力寻找解决方案。我只是希望得到一些关于处理这个问题的最佳方法的想法。

我有一个购物车。 我的网站链接了许多商店。 我的网站是基于重量而不是数量。 我的购物车最大容量为28克。

如果用户在购物车中有物品,他们决定增加重量。旧项目将替换为新项目。

在此过程中,将旧物品重量添加到新物品重量中,然后添加到购物车当前重量。我需要从此过程中排除旧项目权重,仅比较新项目和购物车中的其他项目。

我找到了一个可以调用重复项目并获得权重结果的函数。

我从总数中减去了金额,一切都很好!

错误!我发现获取重复项重量的函数,如果没有重复项,则返回false。现在该函数位于另一个基于返回true或false的函数内。 True表示项目已添加",false表示未添加"未添加"。所以当我的购物车是空的或没有重复时,整个功能会过早地结束。

我只是张贴这个,因为我注意到有很多方法可以实现这一点,很多这些解决方案已经有5年了。

现在这里是魔术发生的地方

<script>

simpleCart.bind('beforeAdd', function (item) {


    var existItem = simpleCart.has(item).get('weight');

    var multi_item = simpleCart.quantity();
    var cartweight = simpleCart.weight();
    var shopid = simpleCart.sid();
    var newweight = $( "div.item_weight" ).text();
    var itemid = $( "div.item_id" ).text();
    var totalweight = parseInt(cartweight) + parseInt(newweight) - parseInt(existItem);


if(shopid != null && shopid != <?=$shopid?> ){
    $( "#pop_fail_store" ).popup( "open" )
    return false;

        }else if (parseInt(totalweight)>=29){
            $( "#pop_fail_weight" ).popup( "open" )
            return false;

                }else if (simpleCart.has(item)){

                        $( "#pop_update" ).popup( "open" )
                            return true;


                                }else { 
                                    return true;
                                    }
        }); 

//SUCCESS       
simpleCart.bind( "afterAdd" , function( item ){
         $( "#pop_success" ).popup( "open" )
}); 

</script>

如果没有任何项目,则返回false,并提前终止该功能。

var existItem = simpleCart.has(item).get('weight');

这些是代表HAS EQUALS和GET

的函数
            has: function (item) {
                var match = false;

                simpleCart.each(function (testItem) {
                    if (testItem.equals(item)) {
                        match = testItem;
                    }
                });
                return match;
            }





me.equals = function (item) {
                    for( var label in _data ){
                        if (Object.prototype.hasOwnProperty.call(_data, label)) {
                            if (label !== 'quantity' && label !== 'id' && label !== 'price' && label !== 'weight') {
                                if (item.get(label) !== _data[label]) {
                                    return false;
                                }
                            }
                        }
                    }
                    return true;
                };








            me.get = function (name, skipPrototypes) {

                var usePrototypes = !skipPrototypes;

                if (isUndefined(name)) {
                    return name;
                }

                // return the value in order of the data object and then the prototype
                return isFunction(_data[name])  ? _data[name].call(me) :
                        !isUndefined(_data[name]) ? _data[name] :

                        isFunction(me[name]) && usePrototypes       ? me[name].call(me) :
                        !isUndefined(me[name]) && usePrototypes ? me[name] :
                        _data[name];
            };

我无法在不搞乱其他功能的情况下更改get,has或equals函数。我只需要它返回的值。

我的第一个计划是将其移出&#34;然后添加&#34;函数并将其保存为就绪函数内的全局变量,然后在启动&#34;之前调用它,然后再添加&#34;功能?这是最好的方式吗?

... AJAX

制作新功能?

或者我可以添加另一个if语句吗?

选择的力量并不总是最好的。我确信有一个简单的答案主演我的脸。

也许有人可以告诉我2017年最有效的方法。

我网站Click Here

中的一个页面

提前致谢!

1 个答案:

答案 0 :(得分:0)

通过查看B/answers函数的代码,您只需在使用之前检查SimpleCart.has()的输出。

SimpleCart.get()