gpt4 book ai didi

asp.net-mvc-3 - 验证完成后运行 mvc3 验证功能

转载 作者:行者123 更新时间:2023-12-05 01:36:11 27 4
gpt4 key购买 nike

我正在使用 MVC3 客户端验证。有没有办法在验证器触发后运行一次函数?

理想情况下,我希望 settngs.errorPlacement 运行并相应地放置我的错误,一旦完成,我希望另一个函数只运行一次。目前我正在从 settngs.errorPlacement 中调用该函数,并且它会针对每个错误运行,这会影响性能。

感激地收到任何帮助。

更新

当在 MVC 中触发不显眼的客户端验证时,每个验证器将调用成功或 errorPlacement 函数。基本上,如果我在一个页面上有 15 个验证器,则这些函数中的任何一个都将为每个验证器运行(即 7 个​​成功、8 个错误或 5 个成功和 10 个错误)。我想要做的是在验证器被循环并且成功和errorPlacement函数在那里完成之后调用一个函数运行一次......

我现在调用了这个函数 15 次,因为我不知道我可以把这个函数放在哪里,它只会运行一次。

最佳答案

jQuery 验证插件 Hook 表单 submit事件处理程序调用其 validate()在提交之前验证表单的功能,从而在验证失败时阻止表单提交。

如果你勾上 submit使用 jQuery 为每个表单添加事件,并在表单底部执行此操作,它将添加您自己的处理程序以在插件处理程序之前执行。这样,您可以调用valid()自己在表单上运行,并在完整的表单验证之后运行您想要的任何自定义代码。插件的valid()函数调用 validate()表单上的函数,然后返回成功/失败的 bool 值。如果您不在乎成功/失败,您可以调用validate()直接调用 valid() .

当您调用 valid()validate()在表单上,​​它将继续与 MVC3 不显眼的客户端验证一起使用验证错误来标记表单,除非现在您可以在调用后执行其他操作。

我在自己的 submit() 中设置了断点处理程序(下)和 jQuery 验证插件 validate()valid()职能。我只看到他们在这个实现中被调用一次,所以你对完整表单的验证不应该执行多次。

当然,该插件还 Hook 了焦点、模糊、keyup 和单击事件,因此各个字段的验证器已经被设计多次调用,因此用户可以立即获得有关失败/已解决的表单字段的反馈。验证是惰性的,因为它在用户在字段中输入值之前不会运行。一旦用户输入一个值并离开该字段,该字段就会被验证。如果一个字段被标记为无效,则重新验证是急切的,因为在各种事件上重复验证一个无效字段,直到发现它是有效的。

将以下内容放在页面底部,所有 form 下方标签。如所写,使用 $("form")选择器,它将处理所有 form 的提交事件页面上的元素。当然,您可以使用 jQuery 选择器来选择特定的 form用于验证的标签。只需调用valid()validate()每当您想要执行验证时,在表单上,​​然后使用您想要执行一次的任何代码跟随它。

要获得验证结果:

<form>
...
</form>

<script type="text/javascript">
$("form").submit(function (e) {
if ($(this).valid() == false) {
alert("yo!"); // execute anything you want following validation
}
});
</script>

或者,如果您不想知道验证结果:
<script type="text/javascript">
$("form").submit(function (e) {
$(this).validate();
alert("yo!"); // execute anything you want following validation
});
</script>

关于asp.net-mvc-3 - 验证完成后运行 mvc3 验证功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8064206/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com