在CompareValidator上添加JS验证

时间:2011-01-06 10:03:50

标签: c# javascript validation comparevalidator

是否可以为CompareValidator添加JS验证函数?
我不能使用CustomValidator。

1 个答案:

答案 0 :(得分:0)

我不确定你是否还需要它,但我认为不是因为这是没有答案的......

好吧,你不能直接这样做,但你可以隐藏负责CompareValidator验证的原始函数并引入新的函数。这是可能的,因为所有验证函数都来自全球范围内的ASP.NET,这是有争议的,但在这种情况下很有帮助。

请找到完成工作的以下模块。它揭示了两种方法。首先称为 addFunction ,允许您添加一个或多个自定义验证功能。此函数应返回布尔,它分别使用三个参数 Validator对象 TargetObject CompareObject 。第二个名为 disableOldFunction 允许您完全摆脱模块调用的旧验证函数,如果您的所有函数都有效。

    var MyModules = {};
    MyModules.CompareValExtension = function ()
    {
        var functions = new Array();
        var oldFunc = null, disabled = false;

        function myCompareValidatorEvaluateIsValid(val)
        {
            var valid = true;
            if (oldFunc && functions.length)
            {
                for (i in functions)
                {
                    valid = functions[i](val, document.getElementById(val.controltovalidate), document.getElementById(val.controltocompare));
                    if (!valid) { break; }
                }
                if (!disabled && valid)
                {
                    valid = oldFunc(val);
                }
            }
            return valid;
        }

        if (typeof CompareValidatorEvaluateIsValid != 'undefined')
        {
            oldFunc = CompareValidatorEvaluateIsValid;
            window.CompareValidatorEvaluateIsValid = myCompareValidatorEvaluateIsValid;
        }

        var me = {};
        me.addFunction = function (func) { if (typeof func == "function") { functions.push(func); } }
        me.disableOldFunction = function () { disabled = true; }
        return me;
    } ();

使用示例:

    MyModules.CompareValExtension.addFunction(function (val, elem, comp)
    {
        return elem.value == "my value"; 
    });
    MyModules.CompareValExtension.disableOldFunction();

警告:请将此模块放在页面底部的某个位置,以确保已经存在默认验证脚本。您还可以稍微重写模块以推迟初始化,直到文档准备就绪。