效果图
项目的正则表达式规则
1:用户名: 大写字母开头 6-20位字符(不允许有符号但是允许有_)
2:密码 大写开头 数字字母符号混合 8-15位
3:确认密码 大写开头 数字字母符号混合 8-15位
4:邮箱 邮箱格式
5:手机号 手机号格式
6:身份证号 身份证号格式
7:地址 中文开头 数字 - 字母 中文混合
项目目录
html代码
由于无法上传bootstrap.min.css
需要样式的需要前往官网下载
bootstrap中文网
正则表达式
用户名
密码
确认密码
邮箱
手机号
身份证号
地址
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("输入错误");
}
}
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前端框架
有喜欢的朋友可以点击下方链接了解
如果需要我的样式请导入bootstrap.min.css
总结
以上所述是小编给大家介绍的JS使用正则表达式判断输入框失去焦点事件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!