JS使⽤正则表达式判断输⼊框失去焦点事件效果图
项⽬的正则表达式规则
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">
</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" ></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" ></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" ></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" ></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" ></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" ></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" ></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]+$/;
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 = ElementsByTagName("span");
var str = "";
//循环获取span的内容
for (var i = 0; i < a.length; i++) {
str+=a[i].innerText;
}
alert("输⼊正确");
}else{
alert("输⼊错误");
}
}
</script>
</body>
</html>
js代码
//输⼊框的校验
/**输⼊框的校验消息显⽰区域的ID 必须按照eleId+"s"
* @param {Object} eleId
* @param {Object} rule
*/
function reg(eleId,rule){
//动态的添加⼀个消息显⽰标签
var inputValue = ElementById(eleId).value;
var result = im());
if(result && inputValue != ""){
}else{
js正则表达式判断数字
}
}
补充说明
我⽬前使⽤的开发⼯具是 HBuilder X
代码风格偏向于bootstrap前端框架
有喜欢的朋友可以点击下⽅链接了解
如果需要我的样式请导⼊bootstrap.min.css
总结
以上所述是⼩编给⼤家介绍的JS使⽤正则表达式判断输⼊框失去焦点事件,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!如果你觉得本⽂对你有帮助,欢迎转载,烦请注明出处,谢谢!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。