jQuery Validate Unobtrusive - 挂钩到单个输入的错误事件

问题描述 投票:6回答:2

我正在使用ASP.NET MVC构建一个站点,并且正在使用jQuery validate unobtrusive库。我想知道是否有办法挂钩显示验证消息的事件,例如在用户输入无效内容的位置(与点击提交按钮的瞬间相反)。

我想这样做的原因是因为我正在设置我的错误消息,例如出现在具有错误的字段上方的迷你弹出窗口 - 即使用绝对定位。由于单个字段可能具有各种不同的验证错误,我希望能够正确设置字段的位置以考虑消息的可变高度。我还需要处理这个事件,这样我就可以在输入元素周围应用一个红色边框的类。

jquery asp.net-mvc jquery-validate unobtrusive-validation
2个回答
7
投票

这里有一个很棒的脚本:https://gist.github.com/beccasaurus/957732/,它为jQuery.validate中的不同事件设置了钩子。它允许您绑定到一堆不同的事件,在您的情况下它将如下所示:

$(function () {
    $('form').addTriggersToJqueryValidate();
    $('form').bind("elementValidation", function (event, element, result) {
        console.log("Something is invalid");
    });
})

非常便利!


0
投票

当用户移动到表单中的下一个元素时,您可以验证并形成元素

$("form#myformid").validate().element("#ModelObject_NameofField");

并使用每个元素的错误位置,如上一个答案所示

jquery - how to use errorPlacement for a specific element?

你的弹出式<div/>应该随着它内部的文本一起增长,所以你只需要在元素旁边左下或右边锚定。

© www.soinside.com 2019 - 2024. All rights reserved.