当前位置:首页 > 生活百科

jq表单验证插件(jquery获取表单数据)

栏目:生活百科日期:2025-03-13浏览:0

from表单数据的合法性验证是个很常见的需求,jQuery提供了一个插件:jquery validate 官网下载。

   若想使用需先引用jquery.validate.js,并且要在jquery.js之后引用。

&<script src="//cdn.bootcss.com/jquery/3.4.1/jquery.js"&>&</script&>&<script src="js/jquery.validate.js"&>&</script&>

   把现在写的项目拿来演示一下,其使用了bootstrap框架。

$(function() {    jQuery.validator.addMethod("regUserName",    function(value, element) {        return this.optional(element) || /^&[0-9]*&[a-zA-Z_\u4e00-\u9fa5]+&[0-9]*$/.test(value);    },    "注册昵称为4-10位数字、下划线、中文或英文字母,但不能全是数字");jQuery.validator.addMethod("isMobile",    function(value, element) {        var length = value.length;        var mobile = /^((\(\d{2,3}\))|(\d{3}\-))?1&[3,8,5]{1}\d{9}$/;        return this.optional(element) || (length == 11 &&&& mobile.test(value));    },    "请正确填写您的手机号码"); //登录帐号合法性验证 jQuery.validator.addMethod("logAccountCheck", function (value, element) { var length = value.length; var mobile = /^((\(\d{2,3}\))|(\d{3}\-))?1&[3,8,5]{1}\d{9}$/; return this.optional(element) || (length == 11 &&&& mobile.test(value)) || /^&[\u0391-\uFFE5\w]+$/.test(value); }, "昵称不符合登录规则");$("#fillForm").validate({ errorElement: 'span', errorClass: 'help-block', focusInvalid: false, rules: { new_userName: { required: true, regUserName: true, minlength: 4, maxlength: 10 }, new_userPwd: { required: true, rangelength: &[5, 15] }, new_userPwd_twice: { required: true, equalTo: "#new_userPwd" }, new_userEmail: { required: true, email: true }, new_userPhone: { required: true, isMobile:true, digits: true, minlength: 11, maxlength: 11 }, new_userBirth: { required: true }, new_userCollege: { required: true }, new_userMajor: { required: true } }, messages: { new_userName: { required: '昵称不能为空', minlength: '昵称最少为4位', maxlength: '昵称最多为10位' }, new_userPwd: { required: '密码不能为空', rangelength: $.validator.format("密码长度必须在 {0} 到 {1} 之间") }, new_userPwd_twice: { required: '此项不能为空', equalTo: '两次输入的密码必须一致' }, new_userEmail: { required: '邮箱不能为空', email: '邮箱格式不正确(例如: xxx@xx.com)' }, new_userPhone: { required: '电话号不能为空', digits: '电话号必须是数字', minlength: '电话号为11位', maxlength: '电话号为11位' }, new_userBirth: { required: '生日不能为空' }, new_userCollege: { required: '学院不能为空' }, new_userMajor: { required: '专业不能为空' } }, highlight: function (element) { $(element).closest('.form-group').addClass('has-error'); }, success: function (label) { label.closest('.form-group').removeClass('has-error').addClass('has-success'); label.remove(); }, errorPlacement: function (error, element) { element.parent('p').after(error); }, submitHandler: function (form) { var result = { "new_userName": $("#new_userName").val(), "new_userPwd": $("#new_userPwd").val(), "new_userEmail": $("#new_userEmail").val(), "new_userPhone": $("#new_userPhone").val(), "new_userBirth": $("#new_userBirth").val(), "new_userGender": $("input&[name='new_userGender']:checked").val(), "new_userCollege": $("#new_userCollege").val() + ',' + $("#new_userMajor").val() }; result.new_userIP = ip; var res = JSON.stringify(result); alert(res); return false; } })})      

   html文件跟平常一样,主要在js中进行验证:

$(function() {    jQuery.validator.addMethod("regUserName",    function(value, element) {        return this.optional(element) || /^&[0-9]*&[a-zA-Z_\u4e00-\u9fa5]+&[0-9]*$/.test(value);    },    "注册昵称为4-10位数字、下划线、中文或英文字母,但不能全是数字");jQuery.validator.addMethod("isMobile",    function(value, element) {        var length = value.length;        var mobile = /^((\(\d{2,3}\))|(\d{3}\-))?1&[3,8,5]{1}\d{9}$/;        return this.optional(element) || (length == 11 &&&& mobile.test(value));    },    "请正确填写您的手机号码"); //登录帐号合法性验证 jQuery.validator.addMethod("logAccountCheck", function (value, element) { var length = value.length; var mobile = /^((\(\d{2,3}\))|(\d{3}\-))?1&[3,8,5]{1}\d{9}$/; return this.optional(element) || (length == 11 &&&& mobile.test(value)) || /^&[\u0391-\uFFE5\w]+$/.test(value); }, "昵称不符合登录规则");$("#fillForm").validate({ errorElement: 'span', errorClass: 'help-block', focusInvalid: false, rules: { new_userName: { required: true, regUserName: true, minlength: 4, maxlength: 10 }, new_userPwd: { required: true, rangelength: &[5, 15] }, new_userPwd_twice: { required: true, equalTo: "#new_userPwd" }, new_userEmail: { required: true, email: true }, new_userPhone: { required: true, isMobile:true, digits: true, minlength: 11, maxlength: 11 }, new_userBirth: { required: true }, new_userCollege: { required: true }, new_userMajor: { required: true } }, messages: { new_userName: { required: '昵称不能为空', minlength: '昵称最少为4位', maxlength: '昵称最多为10位' }, new_userPwd: { required: '密码不能为空', rangelength: $.validator.format("密码长度必须在 {0} 到 {1} 之间") }, new_userPwd_twice: { required: '此项不能为空', equalTo: '两次输入的密码必须一致' }, new_userEmail: { required: '邮箱不能为空', email: '邮箱格式不正确(例如: xxx@xx.com)' }, new_userPhone: { required: '电话号不能为空', digits: '电话号必须是数字', minlength: '电话号为11位', maxlength: '电话号为11位' }, new_userBirth: { required: '生日不能为空' }, new_userCollege: { required: '学院不能为空' }, new_userMajor: { required: '专业不能为空' } }, highlight: function (element) { $(element).closest('.form-group').addClass('has-error'); }, success: function (label) { label.closest('.form-group').removeClass('has-error').addClass('has-success'); label.remove(); }, errorPlacement: function (error, element) { element.parent('p').after(error); }, submitHandler: function (form) { var result = { "new_userName": $("#new_userName").val(), "new_userPwd": $("#new_userPwd").val(), "new_userEmail": $("#new_userEmail").val(), "new_userPhone": $("#new_userPhone").val(), "new_userBirth": $("#new_userBirth").val(), "new_userGender": $("input&[name='new_userGender']:checked").val(), "new_userCollege": $("#new_userCollege").val() + ',' + $("#new_userMajor").val() }; result.new_userIP = ip; var res = JSON.stringify(result); alert(res); return false; } })})    

   简单用法:

   1.:rules里定义输入框规则,常见的有required, minlength, maxlength, email, 其中使用输入框的name属性来指定输入框。

   2:messages里定义当输入内容不符合规则时显示的信息,如果自定义则显示默认的错误信息。

   3:可以自定义规则,比如上面代码开头部分定义了自定义规则,可以根据自己的需求仿照代码即可,而且网上也提供了现成的自定义验证规则。

   4:当输入框均符合规则时,可以点击提交,此时,会指定submitHandler函数。

“jq表单验证插件(jquery获取表单数据)” 的相关文章

外星人台式电脑怎么样(性价比高的外星人台式电脑简评)

十一长假快要到来之际,你的电竞装备是否也已经整装待发?近日,戴尔旗下高端专业电竞游戏品牌外星人推出了全新造型设计、性能体验大进阶的外星人AuroraR9全系列新...

声线测试适合什么歌(找适合自己嗓音的歌曲软件)

在一个人的歌声中能让每一个音的质量达标,不是随波逐流,唱到哪里就算哪里。高质量的声音好象不是从喉咙里发出,而是从鼻咽腔到胸腔布满了声音,或者说是全身在振动。如果...

做直播必备的台词有哪些(新手直播话术攻略)

做主播,刚开始打开直播间的时候,最怕的就是冷场,所以掌握一套直播话术技巧开场白很有必要!接下来我就分享一套“见人说人话,见鬼说鬼话”的直播话术技巧开场白!直播话...

b75主板最高配什么cpu和显卡(主板小板和大板区别)

一、主流CPU的型号及主板选择目前市面上的CPU型号千奇百怪,让各种想配电脑的朋友们应接不暇,选择困难,个人意见是,先想好自己想要做什么,然后看看本文,做出选择...

交互工程师是做什么的(交互设计定义及其职责)

最近几年,交互设计这个词被提得非常频繁。可是,UI设计见了一大把,你却很少能见到真正的交互设计师。那么到底什么才是真正的交互设计呢?怎样才能成为真正的交互设计师...

创业园区是做什么的(昆明4家创业园区内况)

近日,昆明市就业工作领导小组办公室下发《关于认定2020年度昆明市新型创业创新孵化服务园区的通知》,昆明经开区的紫云青鸟创业创新孵化服务园区、四库文创·得胜园获...

ar营销是什么意思(3分钟了解ar营销)

AR正在迅速成为市场营销和广告行业热门趋势之一,被认为是与消费者建立连接和增加参与度的创新方式。几乎每天都会有各种品牌传出使用AR营销的消息。但在如此火热的趋势...

m.2 nvme接口定义(m.2接口sata和nvme区别)

我们在购买固态硬盘时经常能看到PCIe、M.2、SATA、NVMe等等一系列的英文缩写,搞得人头晕眼花,好不容易一个一个查清楚了,没过几天又忘了,下面我就系统为...

2020年有哪些创业小项目,四个适合年轻人创业的好项目推

这都四月份了,2020年过去了接近三分之一,社会上有许多被疫情搞得焦头烂额,措手不及的创业者,都还没用找到努力的方向,不知道该做些什么能赚钱。我认为,客观面对2...

华为mate9多少钱一部(一览华为mate9手机参数和报价)

今日(11月14日)下午14:30,年度重磅旗舰华为Mate9国行版正式发布,分为Mate9/9Pro以及Mate9保时捷设计版等三款,并将于11月14日18:...