validation指针对表单input的一个校验插件,可以

validation Docs 1.怎么实现的

[1].代码结构:

//一些公共调用方法 var action = {}; //jquery原型上添加相应校验方法 $.fn.extend({ validNull: function(){}, validCn: function(){}, validPhone: function(){} //等等... }); //外部调用方法 var valid = { init: function(){},//全局初始化 register: function(){},//自定义注册事件 hasError: function(){}//表单提交时调用,全局验证 };

[2].解析data-valid的实现:

var inputList = $('input[data-valid]'); inputList.map(function(index, ele) { var input = $(ele), data = eval('(' + input.data('valid') + ')'), validType = data.type, errorText = data.text || ''; switch (validType) { case 'validLen': input.validLen(data.min, data.max); break; default: input[validType](errorText); } }); 2.怎么使用

校验为空:<input type="text" data-valid="{type:'validNull'}"> 校验中文:<input type="text" data-valid="{type:'validCn',text:'请输入中文'}"> 校验电话:<input type="text" data-valid="{type:'validPhone',text:'请输入正确的手机号'}"> 其他类似...

//require调用 require(['validation'],function(valid){ //插件初始化 valid.init(); //自定义校验规则 valid.register({ reg:'/^[1-9][0-9]{5,11}$/', type:'validQQ' }); //表单提交时验证,dom为表单jquery对象,dom可选,不传则默认所有表单 if(valid.hasError(dom)) return; }); //jquery直接调用 $.valid.init(); $.register(...); $.hasError(dom);

需要把index.css中尾部validation样式copy到你的样式文件

3.有什么优点
直接在dom元素中添加校验规则和错误提示信息,用起来比较方便 可以通过register方法定制校验规则,有一定扩展性
4.缺点和不足
提示信息位置制定在下方,不能自定义显示位置 只实现了双层校验(先判断为空,再接着验证相应的规则),不能依次逐层校验

版权声明:

1、该文章(资料)来源于互联网公开信息,我方只是对该内容做点评,所分享的下载地址为原作者公开地址。
2、网站不提供资料下载,如需下载请到原作者页面进行下载。