我正在使用jQuery的验证插件。有一件非常奇怪的事情是,当我以这种方式添加规则时:
$(document).ready(function () {
$.validator.addMethod("endDateGreaterThan", function (value, element, params) {
if (value != "" && $(params).val() != "") {
var endDate = formatValidateDate(value);
var startDate = formatValidateDate($(params).val());
if (startDate == null || endDate == null)
return true;
return new Date(endDate) >= new Date(startDate);
}
return true;
}, "");
var validator = $("#form").validate({
rules: {
StartDate: "required",
EndDate: {
required: true,
endDateGreaterThan: "#StartDate"
},
DiscountRate: {
required: true,
max: 100,
min: 1
}
},
messages: {
StartDate: {
required: "ErrorMessageStartDateRequired"
},
EndDate: {
required: "ErrorMessageEndDateRequired",
endDateGreaterThan: "ErrorMessageEndDateGreaterThanStartDate"
},
DiscountRate: {
required: "ErrorMessageDiscountRateRequired",
max: "Global.ErrorMessageDiscountRateRange",
min: "Global.ErrorMessageDiscountRateRange"
}
}
});
没有添加规则。如果我调试JS文件并进入jquery.validation.js文件中的validate方法,我发现传递给validate方法的选项为空。
但是如果我动态添加规则,就像这样:
$("#StartDate").rules("add", {
required: true,
messages: {
required: "StartDate is required"
}
});
规则将会按照应有的方式添加。
我正在使用ASP.net mvc。
欢迎提出任何建议。
form
的渲染 HTML。在第一种情况下,当规则在.validate()
中定义时,必须使用name
属性作为选择器。在第二种情况下,使用rules('add')
方法,通过id
属性来定位字段。看到区别了吗?如果我们能够看到表单的 HTML,你的rules
选择器是否与字段的name
属性匹配? - Sparky