simpleCart(js)选择选项验证

时间:2012-03-21 00:40:06

标签: php javascript jquery validation

尝试在添加到购物车按钮上设置一些验证,以便在我的wordpress网站上的simplecart书架项目上显示尺寸和颜色的下拉选项。我可以获取弹出警报并阻止添加项目,但这是错误的,因为即使选择了正确的值,警报也会弹出。我一直在搜索这几天,并且发现有几个人在没有回复的情况下问同样的问题,所以关于如何以及如果可能的任何输入将是惊人的。

这是添加到购物车功能:

me.add = function () {
    var me=this;
    /* load cart values if not already loaded */
    if( !me.pageIsReady     ) { 
        me.initializeView(); 
        me.update();    
    }
    if( !me.isLoaded        ) { 
        me.load(); 
        me.update();    
    }

    var newItem = new CartItem();

    /* check to ensure arguments have been passed in */
    if( !arguments || arguments.length === 0 ){
        error( 'No values passed for item.');
        return;
    }
    var argumentArray = arguments;
    if( arguments[0] && typeof( arguments[0] ) != 'string' && typeof( arguments[0] ) != 'number'  ){ 
        argumentArray = arguments[0]; 
    } 

    newItem.parseValuesFromArray( argumentArray );
    newItem.checkQuantityAndPrice();

我想要实现的代码:

if( item_Size = "none" ){
        alert("Please select a size");
        return;
    }


if( item_Color = "none" ){
        alert("Please select a color");
        return;
    }

现在我是一个菜鸟,所以我甚至不确定它存储值的位置,所以它可能是任何设置变量名称,代码可能完全错误,但没有一个是默认选择选项的值。

这是加载和保存cookie的方式:

me.load = function () {
    var me = this;
    /* initialize variables and items array */
    me.items = {};
    me.total = 0.00;
    me.quantity = 0;

    /* retrieve item data from cookie */
    if( readCookie('simpleCart') ){
        var data = unescape(readCookie('simpleCart')).split('++');
        for(var x=0, xlen=data.length;x<xlen;x++){

            var info = data[x].split('||');
            var newItem = new CartItem();

            if( newItem.parseValuesFromArray( info ) ){
                newItem.checkQuantityAndPrice();
                /* store the new item in the cart */
                me.items[newItem.id] = newItem;
            }
        }
    }
    me.isLoaded = true;
};



/* save cart to cookie */
me.save = function () {
    var dataString = "";
    for( var item in this.items ){
        dataString = dataString + "++" + this.items[item].print();
    }
    createCookie('simpleCart', dataString.substring( 2 ), 30 );
};

完整的simpleCart代码可在此处找到:simplecartjs.com

任何帮助将不胜感激,我已经尝试过其他表单验证技术,但由于simplecart存储变量的方式,因此无法使用任何用于后验证的方法。请帮助!!

感谢您的时间和努力。

1 个答案:

答案 0 :(得分:1)

在您尝试实现的代码中,您将“none”的值赋给变量“item_size”。因为它将是真的,弹出窗口将显示。你想在进行比较时使用两个“=”。

您的代码:

if( item_Size = "none" )

<强>固定

if( item_Size == "none" )

乍一看应该解决问题。祝你好运。