是否可以为CompareValidator添加JS验证函数?
我不能使用CustomValidator。
答案 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();
警告:请将此模块放在页面底部的某个位置,以确保已经存在默认验证脚本。您还可以稍微重写模块以推迟初始化,直到文档准备就绪。