我正在使用ASP.NET MVC构建一个站点,并且正在使用jQuery validate unobtrusive库。我想知道是否有办法挂钩显示验证消息的事件,例如在用户输入无效内容的位置(与点击提交按钮的瞬间相反)。
我想这样做的原因是因为我正在设置我的错误消息,例如出现在具有错误的字段上方的迷你弹出窗口 - 即使用绝对定位。由于单个字段可能具有各种不同的验证错误,我希望能够正确设置字段的位置以考虑消息的可变高度。我还需要处理这个事件,这样我就可以在输入元素周围应用一个红色边框的类。
这里有一个很棒的脚本:https://gist.github.com/beccasaurus/957732/,它为jQuery.validate中的不同事件设置了钩子。它允许您绑定到一堆不同的事件,在您的情况下它将如下所示:
$(function () {
$('form').addTriggersToJqueryValidate();
$('form').bind("elementValidation", function (event, element, result) {
console.log("Something is invalid");
});
})
非常便利!
当用户移动到表单中的下一个元素时,您可以验证并形成元素
$("form#myformid").validate().element("#ModelObject_NameofField");
并使用每个元素的错误位置,如上一个答案所示
jquery - how to use errorPlacement for a specific element?
你的弹出式<div/>
应该随着它内部的文本一起增长,所以你只需要在元素旁边左下或右边锚定。