ExtJS加入自定义验证JS函数

有些复杂的验证我们是需要我们写脚本验证的。那么怎么做到通用呢?比如下面的情况:

ExtJS加入自定义验证JS函数_第1张图片

左侧S、M、L、XL总数不能超过2件,右侧不能超过6件。首先可以定义以下验证JS,来验证数量是否超过最大值。

function valSumMax(ids, maxValue, msg) {
    if (ids != null && ids.length > 0) {
        var _temp = 0;
        for (var i = 0; i < ids.length; i++) {
            var value = Ext.getCmp(ids[i]).getValue();
            if (!isNaN(value)) {
                _temp += value;
                if (_temp > maxValue) {
                    var message = { 'IsVal': false, 'Message': msg != "" ? msg : ("超过最大值" + maxValue + "。") };
                    return message;
                }
            }
        }
    }
    var message = { 'IsVal': true, 'Message': '' };
    return message;
}

为了做到通用,于是又定义以下JS函数

function CustomValidator() {
    var msg = valSumMax(ids1, 2, "美容顾问服装最多只能填2件。请修改总数。");
    if (!msg.IsVal)
        return msg;2011大智慧下载
    msg = valSumMax(ids2, 6, "美容师服装最多只能填6件。请修改总数。");
    return msg;
}
function ValCustomValidator(isVal, valid) {
    if (typeof (valid) != 'undefined' && (!valid))
        return valid;
    if (typeof (isVal) == 'undefined' || isVal == null || isVal) {
        var msg = CustomValidator();
        if (!msg.IsVal) {
            Ext.MessageBox.show({
                title: '错误',
                msg: msg.Message,
                buttons: Ext.MessageBox.OK,
                icon: Ext.MessageBox.ERROR
            });
            return false;
        } else {
            return true;胸围怎么算
        }
    } else {
        return CustomValidator();
    }
}

最后,要写监听的验证Handler了。可以这么写:

_fp.Listeners.ClientValidation.Handler =
               @"
                            var isCheckd=valid;var msgs;var msg='';
                            if(typeof(ValCustomValidator)=='function')
                            {
                                msgs=ValCustomValidator(false,valid);
                                if(typeof(msgs.IsVal)!='undefined')
                                {
                                    isCheckd=msgs.IsVal;
                                    if(msgs.Message!='')
                                    msg='<span style=\'color:red;\'>'+msgs.Message+'</span>';
                                }
                                else
                                    isCheckd=msgs;
                            }
                         #{btnSave}.setDisabled(!isCheckd);
                         #{tbSave}.setDisabled(!isCheckd);
                         #{btnSumbit1}.setDisabled(!isCheckd);
                         #{btnSumbit2}.setDisabled(!isCheckd);
                         var valCs=isCheckd ? 'valaccept' : 'valexclamation';
                         if (msg=='') 
                            msg=isCheckd ? '<span style=\'color:green;\'>验证通过,可以提交数据</span>' : '<span style=\'color:red;\'>输入有误,请检查标红的输入项。</span>';
                         this.getBottomToolbar().setStatus({text :msg, iconCls: valCs});showMsg('温馨提示',msg,valCs);
                        ";

你可能感兴趣的:(ext,脚本,FP)