ASP.NET MVC异步验证是如何工作的01,jQuery的验证方式、错误信息提示、validate方法的背后
ASP.NET MVC借助jQuery的验证机制,提供了一套从客户端到服务端异步验证的解决方案,通常情况下,用起来相当方便。但面对一些相对特殊的情况,可能会遇到验证失效的场景,比如在使用ajax动态异步加载视图的时候。所以,有必要了解其背后运行的原理。首先从了解jQuery验证开始。本篇主要包括:
● jQuery验证的各种方式
● 错误信息是如何显示的
● 调用validate方法的背后发生了什么?
jQuery验证的各种方式
□ 通过class属性值实施验证规则
使用jQuery对表单元素进行验证,一种做法是通过为表单元素添加class属性值实现的。
如果想对jQuery验证汉化,可通过NuGet安装jQuery.Validation.Localization:
Install-Package jQuery.Validation.Localization
<form><input id="Name" name="Name" type="text" class="required"/><hr/><input type="submit" value="提交"/></form>@section scripts{<script src="~/Scripts/jquery.validate.js"></script><script src="~/Scripts/localization/messages_zh.js"></script><script type="text/javascript">$(function() {$('form').validate();});</script>}

□ 通过$.validator.addClassRules方法自定义验证规则
通过 $.validator.addClassRules方法还可以自定义验证规则,然后把新的规则名作为表单元素class属性的值。
<form><input id="Name" name="Name" type="text" class="name" /><br/><input id="z" name="z" class="zip" type="text"/><hr/><input type="submit" value="提交"/></form>@section scripts{<script src="~/Scripts/jquery.validate.js"></script><script src="~/Scripts/localization/messages_zh.js"></script><script type="text/javascript">$(function() {$.validator.addClassRules({name: {required: true,minlength: 2},zip: {required: true,digits: true,minlength: 5,maxlength: 5}});$('form').validate();});</script>}

□ 通过$.validator.addMethod自定义验证规则
<form><input id="e" type="text" name="firstName"/><hr/><input type="submit" value="提交"/></form>@section scripts{<script src="~/Scripts/jquery.validate.js"></script><script src="~/Scripts/localization/messages_zh.js"></script><script type="text/javascript">$(function () {$.validator.addMethod("notnumbers", function(value, element) {return !/[0-9]*/.test(value);}, "不能输入数字");$('form').validate({rules: {firstName: {notnumbers: true}}});});</script>}

□ 通过validate方法的json参数
通过validate方法的json参数,也可为表单元素设置验证规则。
<form><input id="e" type="text" name="userEmail"/><hr/><input type="submit" value="提交"/></form>@section scripts{<script src="~/Scripts/jquery.validate.js"></script><script src="~/Scripts/localization/messages_zh.js"></script><script type="text/javascript">$(function() {$('form').validate({rules: {userEmail: {email: true,required: true}}});});</script>}

□ 动态添加或删除验证规则
通过rules方法可以为表单元素动态添加验证规则。
<form><input id="e" type="text" name="userEmail"/><hr/><input type="submit" value="提交"/></form>@section scripts{<script src="~/Scripts/jquery.validate.js"></script><script src="~/Scripts/localization/messages_zh.js"></script><script type="text/javascript">$(function() {$('form').validate({rules: {userEmail: {required: true}}});//为表单元素动态添加验证规则$('#e').rules('add', {minlength: 2,maxlength:5});});</script>}

通过rules方法可以为表单元素动态移除验证规则。
<form><input id="e" type="text" name="userEmail"/><hr/><input type="submit" value="提交"/></form>@section scripts{<script src="~/Scripts/jquery.validate.js"></script><script src="~/Scripts/localization/messages_zh.js"></script><script type="text/javascript">$(function() {$('form').validate({rules: {userEmail: {required: true}}});//为表单元素动态添加验证规则$('#e').rules('add', {minlength: 2,maxlength:5});//为表单元素动态移除验证规则$('#e').rules('remove', 'minlength');});</script>}

错误信息是如何显示的
□ 通过messages对象
<form><input id="e" type="text" name="userEmail"/><hr/><input type="submit" value="提交"/></form>@section scripts{<script src="~/Scripts/jquery.validate.js"></script><script src="~/Scripts/localization/messages_zh.js"></script><script type="text/javascript">$(function() {$('form').validate({rules: {userEmail: {required: true,email: true}},messages: {userEmail: {required: "*",email: "哈哈,输入正确的email"}}});});</script>}

□ 通过$.validator.addMethod重写错误提示
通过$.validator.addMethod方法还可以为默认验证规则重写错误提示信息。
<form><input id="Name" name="Name" type="text" class="name" /><br/><input id="z" name="z" class="zip" type="text"/><hr/><input type="submit" value="提交"/></form>@section scripts{<script src="~/Scripts/jquery.validate.js"></script><script src="~/Scripts/localization/messages_zh.js"></script><script type="text/javascript">$(function() {$.validator.addClassRules({name: {newrequired: true,minlength: 2},zip: {required: true,digits: true,minlength: 5,maxlength: 5}});$.validator.addMethod("newrequired", $.validator.methods.required, "我说这个字段必填");$('form').validate();});</script>}

□ 通过title属性值重写错误提示
通过表单元素的title属性值是重写错误提示最直接的做法。
<input id="z" name="z" class="zip" type="text" title="我是通过title设置的错误提示"/>

调用validate方法的背后发生了什么?
→通过表单事件触发验证
这些表单事件包括focusin, focusout, keyup, submit, click,这些事件是可以禁止的。
$(".selector").validate({onfocusout: false,onkeyup: false,onclick: false,onsubmit: false});
→获取validate对象,该对象包含了所有了验证规则和设置
可以通过如下方式获取validate对象。
var validator = $('.selector').data("validator");
→对各个表单元素进行验证
下一篇将试着去了解ASP.NET MVC异步验证的表单html元素是如何创建的。
ASP.NET MVC异步验证是如何工作的01,jQuery的验证方式、错误信息提示、validate方法的背后的更多相关文章
- ASP.NET MVC异步验证是如何工作的02,异步验证表单元素的创建
在上一篇"ASP.NET MVC异步验证是如何工作的01,jQuery的验证方式.错误信息提示.validate方法的背后"中,了解了jQuery如何验证,如何显示错误信息,本篇要 ...
- ASP.NET MVC异步验证是如何工作的03,jquery.validate.unobtrusive.js是如何工作的
在上一篇"ASP.NET MVC异步验证是如何工作的02,异步验证表单元素的创建"中了解了ASP.NET异步验证是如何创建表单元素的,本篇体验jquery.validate.uno ...
- asp.net mvc异步查询
对于asp.net mvc异步查询 如何做MVC异步查询,做列表页面. 查询是项目中必不可少的工作,而且不同的项目不同的团队,都有自己的简单方法.Asp.net mvc 有自己独特的优势,下面是结合m ...
- c#异步编程(三)—ASP.NET MVC 异步控制器及EF异步操作
ASP.NET MVC 异步控制器及EF异步操作 异步控制器 ASP.NET MVC2后开始了对异步请求管道的支持,异步请求管道的作用是允许web服务器处理长时间运行的请求,比如 那些花费大量时间等待 ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(15)-用户登录详细错误和权限数据库模型设计
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(15)-用户登录详细错误和权限数据库模型设计 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) ...
- AngularJS 表单数据验证及错误信息提示
一.表单验证基本原理 表单验证包括两个主题: 定义验证规则,验证数据有效性. 显示验证结果,把验证结果以友好的方式显示给用户. H5内置一些验证功能,并会显示内置的错误提示信息,先要禁用它,在< ...
- ASP.NET MVC和WebForm 轻松实现前端和后端的双重验证 jquery.validate+ValidationSugar
上次不足的改进 可能上一个贴子给大家带来很多误解,所以我这次把DEMO完善了两个版本 [ASP.NET WEBFROM]和[ ASP.NET MVC] 修改了一些BUG,并且修改了一些细了 在上个贴子 ...
- 对于asp.net mvc异步查询
如何做MVC异步查询,做列表页面. 查询是项目中必不可少的工作,而且不同的项目不同的团队,都有自己的简单方法.Asp.net mvc 有自己独特的优势,下面是结合mvc实现一个产品列表的Demo. 问 ...
- ASP.NET MVC 学习7、为Model Class的字段添加验证属性(validation attribuate)
Adding Validation to the Model ,在Model中添加数据验证 参考:http://www.asp.net/mvc/tutorials/mvc-4/getting-star ...
随机推荐
- 利用shell找出15分钟内修改的文件
如果你的文件只是生成不会修改的话,可以这样: find * -mmin -15 2>/dev/null 如果可能修改,则需要这样(先创建一个 15 分之前的时间戳的文件,然后找比这个文件新的文件 ...
- WPF的EventAggregator的发布和订阅
EventAggregator是Prism中专门处理ViewModel与ViewModel之间事件传递的类对象,它提供了针对事件的发布方法和订阅方法,所以可以非常方便的来管理事件.下面分几步来实现相关 ...
- yolov2在CUDA8.0+cudnn8.0下安装、训练、检测经历
这次用yolov2做检测时遇到个大坑,折腾了我好几天,特以此文记录之. 一.安装cuda+cudnn 它们的版本必须要匹配,否则训练后检测不出目标! 1.下载cuda8.0.61_375.26_lin ...
- 可视化并理解CNN
参考:https://zhuanlan.zhihu.com/p/24833574 学习论文[1311.2901] Visualizing and Understanding Convolutional ...
- 无root或sudo权限,安装mysql
这其实才是真正的linux,恰当使用权限. 网上找到的中文博客,基本上就那么几篇原创,都要编译源码.但89服务器性能太差编译一次大约半小时无法忍受,在本机上创建了standard用户去尝试几篇博客所言 ...
- Java第三阶段学习(十一、Servlet基础、servlet中的方法、servlet的配置、ServletContext对象)
一.Servlet简介 1.什么是servlet: sun公司提供的一套规范(接口),用来处理客户端请求.响应给浏览器的动态资源.但servlet的实质就是java代码,通过java的API动态的向 ...
- [java] 数据处理
背景: 有一组30天内的温度与时间的数据,格式如下: 详细情况:共30天的8k+项数据,每天内有260+项,每个记录温度的时间精确到秒 任务就是想根据这样的数据找到规律,来完成给定具体的时间预测出此时 ...
- spring-boot集成Springfox-Swagger2
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Co ...
- Android组件化方案及组件消息总线modular-event实战
背景 组件化作为Android客户端技术的一个重要分支,近年来一直是业界积极探索和实践的方向.美团内部各个Android开发团队也在尝试和实践不同的组件化方案,并且在组件化通信框架上也有很多高质量的产 ...
- tornado登陆装饰器
tornado作为鼎鼎大名的web异步框架,用来作为高性能服务器以及web框架都是首选.自从python3.4加入了asyncio原生协程后,tornado的最新版本也开始使用了原生的协程.定义协程函 ...