我有一个与 jquery 验证器一起使用的自定义验证方法。我试图让错误消息动态生成。
我用谷歌搜索过,我最常看到的答案显示在这个 stackoverflow 帖子中。
但是,当我尝试自己实现它时,它不起作用。它只是忽略我更新的消息,只显示原始消息。
这是我的代码,位于 jquery.ready() 函数内。我究竟做错了什么?
注意:“g$”是我们对 jquery 的简写。
var jsBlackoutDateMessage = "Tournaments cannot be scheduled on blackout dates.";
var jsBlackoutDateMessageFunction = function () {
return jsBlackoutDateMessage;
};
g$.validator.addMethod(
"notBlackoutDate",
function (value, element) {
var notBlackoutDate = true;
if (g$.inArray(value, jsBlackoutDates) != -1) {
notBlackoutDate = false;
}
if (notBlackoutDate == false) {
// year
var year = new Date(g$.trim(g$('#txtDate').val())).getFullYear();
var blackoutDatesForYear = jsBlackoutDates.filter(function (item) {
return endsWith(item, year.toString());
})[0];
var blackoutDatesForYearMessage = [];
blackoutDatesForYearMessage.push("Tournaments cannot be scheduled on blackout dates.");
blackoutDatesForYearMessage.push("<ul>");
g$.each(blackoutDatesForYear, function (key, value) {
blackoutDatesForYearMessage.push("<li>");
blackoutDatesForYearMessage.push(new Date(value).toLocaleDateString());
blackoutDatesForYearMessage.push("</li>");
});
blackoutDatesForYearMessage.push("</ul>");
jsBlackoutDateMessage = blackoutDatesForYearMessage.join("");
}
return this.optional(element) || notBlackoutDate;
},
jsBlackoutDateMessageFunction
);