JavaScript

超轻量级php框架startmvc

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

更新时间:2020-09-18 02:54:01 作者:startmvc
效果图项目的正则表达式规则1:用户名:大写字母开头6-20位字符(不允许有符号但是允许有_)2:

效果图

在这里插入图片描述

项目的正则表达式规则

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

js 输入框 js 正则表达式