JS使用正则表达式判断输入框失去焦点事件

时间:2021-05-26

效果图

项目的正则表达式规则

1:用户名: 大写字母开头 6-20位字符(不允许有符号但是允许有_)
2:密码 大写开头 数字字母符号混合 8-15位
3:确认密码 大写开头 数字字母符号混合 8-15位
4:邮箱 邮箱格式
5:手机号 手机号格式
6:身份证号 身份证号格式
7:地址 中文开头 数字 - 字母 中文混合

项目目录

html代码

由于无法上传bootstrap.min.css
需要样式的需要前往官网下载
bootstrap中文网

<!DOCTYPE html><html> <head> <meta charset="utf-8"> <title></title> <link rel="stylesheet" href="css/bootstrap.min.css" /> <script src="js/reg.js"></script> </head> <body> <form class="form-horizontal col-md-offset-3" role="form"> <div class="form-group"> <div class="col-md-offset-3"> <h2>正则表达式</h2> </div> </div> <div class="form-group"> <label class="col-sm-2 control-label">用户名</label> <div class="col-lg-3"> <input class="form-control" id="UserName" name="UserName" type="text" onfocusout="verify(UserName)"> </div> <span id="UserNames" style="font-size: 16pt;"></span> </div> <div class="form-group"> <label class="col-sm-2 control-label">密码</label> <div class="col-lg-3"> <input class="form-control" id="pwd" name="pwd" type="text" onfocusout="verify(pwd)"> </div> <span id="pwds" style="font-size: 16pt;"></span> </div> <div class="form-group"> <label class="col-sm-2 control-label">确认密码</label> <div class="col-lg-3"> <input class="form-control" id="affirmPwd" name="affirmPwd" type="text" onfocusout="verify(affirmPwd)"> </div> <span id="affirmPwds" style="font-size: 16pt;"></span> </div> <div class="form-group"> <label class="col-sm-2 control-label">邮箱</label> <div class="col-lg-3"> <input class="form-control" type="text" id="email" name="email" onfocusout="verify(email)"> </div> <span id="emails" style="font-size: 16pt;"></span> </div> <div class="form-group"> <label class="col-sm-2 control-label">手机号</label> <div class="col-lg-3"> <input class="form-control" type="text" id="cellPhone" name="cellPhone" onfocusout="verify(cellPhone)"> </div> <span id="cellPhones" style="font-size: 16pt;"></span> </div> <div class="form-group"> <label class="col-sm-2 control-label">身份证号</label> <div class="col-lg-3"> <input class="form-control" id="identityCard" name="identityCard" type="text" onfocusout="verify(identityCard)"> </div> <span id="identityCards" style="font-size: 16pt;"></span> </div> <div class="form-group"> <label class="col-sm-2 control-label">地址</label> <div class="col-lg-3"> <input class="form-control" id="site" name="site" type="text" onfocusout="verify(site)"> </div> <span id="sites" style="font-size: 16pt;"></span> </div> <div class="form-group"> <div class="col-lg-3 col-md-offset-3"> <input type="button" class="btn btn-primary btn-lg" value="校验" onclick="OnClick()"> </div> </div> </form> <script type="text/javascript"> var ID = ""; function verify(ID) { //设置一个ID用来传参 switch (ID) { //根据传过来的input的"ID"判断进行不同的正则表达式验证 //用户名验证 case UserName: //用户名的正则表达式 var UserNameRule = /^[A-Z][a-zA-Z0-9_]{6,20}$/; //调用下面的编写的js方法,传入input的id和正则表达式 reg("UserName", UserNameRule); break; case pwd: //密码验证 var pwdRule = /^[A-Z][a-zA-Z0-9_]{8,15}$/; reg("pwd", pwdRule); break; case affirmPwd: //密码确认验证 var affirmPwdRule = /^[A-Z][a-zA-Z0-9_]{8,15}$/; reg("affirmPwd", affirmPwdRule); break; case email: //邮箱验证 var emailRule = /^[A-z0-9]+@[a-z0-9]+.com$/; reg("email", emailRule); break; case cellPhone: // 手机号验证 var cellPhoneRule = /^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$/; reg("cellPhone", cellPhoneRule); break; case identityCard: //身份证号验证 var identityCardRule = /^([1-9]){1}[0-9]{17}|[1-9]{1}[0-9]{16}(x|X)?$/; reg("identityCard", identityCardRule); break; case site: //地址验证 var siteRule = /^[\u4e00-\u9fa5]+[\u4E00-\u9FA5A-Za-z0-9_]+$/; reg("site", siteRule); break; //设置特殊情况 default: alert("操作错误!请关闭网页") break; } } //提交验证判断是否都符合正则表达式 function OnClick(){ //获取所有的span标签 var a = document.getElementsByTagName("span"); var str = ""; //循环获取span的内容 for (var i = 0; i < a.length; i++) { str+=a[i].innerText; } if(str == "√√√√√√√"){ alert("输入正确"); }else{ alert("输入错误"); } } </script> </body></html>

js代码

//输入框的校验/**输入框的校验 消息显示区域的ID 必须按照eleId+"s" * @param {Object} eleId * @param {Object} rule */function reg(eleId,rule){ //动态的添加一个消息显示标签 var inputValue = document.getElementById(eleId).value; var result = rule.test(inputValue.trim()); if(result && inputValue != ""){ document.getElementById(eleId+"s").innerHTML="√"; document.getElementById(eleId+"s").style.color="green"; }else{ document.getElementById(eleId+"s").innerHTML="×"; document.getElementById(eleId+"s").style.color="red"; } }

补充说明

我目前使用的开发工具是 HBuilder X
代码风格偏向于bootstrap前端框架

有喜欢的朋友可以点击下方链接了解

Hbuilder官网

bootstrap中文网

如果需要我的样式请导入bootstrap.min.css

总结

以上所述是小编给大家介绍的JS使用正则表达式判断输入框失去焦点事件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章