inform表单验证,正则表达式,用户名,身份证,密码,验证码
最近利用空闲时间写了部分表单验证,包括用户名,身份证,密码,验证码,仅为自己巩固最近所学的知识
表单的样式使用的是table布局,因为觉得DIV布局定位比较麻烦,table有三列,分别为基本信息,输入的信息,提示信;输入信息栏,插入表单
<body>
<table>
<tr>
<td><p>会员名:</p></td>
<td><input type="text" name="" id="Name" value="" required="required"/></td>
<td id="warn"></td>
</tr>
<tr>
<td><p>身份证号:</p></td>
<td><input type="text" name="" id="Idcard" value="" /></td>
<td id="warn2"></td>
</tr>
<tr>
<td><p>登录密码:</p></td>
<td><input type="password" name="" id="passWord" value="" /></td>
<td id="warn3"></td>
</tr>
<tr>
<td><p>确认密码:</p></td>
<td><input type="password" name="" id="ensure" value="" disabled="disabled"/></td>
<td id="warn4"></td>
</tr>
<tr id="login">
<td><p>验证码:</p></td>
<td>
<input type="text" name="" id="write" value=""/>
<input type="button" name="" id="yan" value="" disabled="disabled"/>
<button id="faSong" onclick="pro();Color ()">看不清</button>
</td>
<td id="warn5"></td>
</tr>
</table>
<span id="ziFu"></span>
<span id="low">弱</span>
<span id="mid">中</span>
<span id="high">强</span>
</body>
进行少量CSS样式修改,达到布局效果,整体效果如下:
td>p{
text-align: right;
margin-bottom: 10px;
}
input{
margin:;
padding:;
}
#ziFu{//用户名字符统计样式
position: absolute;
left: 85px;
top: 50PX;
}
span{//提示信息栏样式
font-size: 10px;
color:red;
}
#low,#mid,#high{//密码强度显示样式
width:83px ;
color: black;
text-align: center;
}
#low{
position: absolute;
left: 83px;
top: 150PX;
background-color: red;
}
#mid{
position: absolute;
left: 166px;
top: 150PX;
background-color: orange;
}
#high{
position: absolute;
left: 249px;
top: 150PX;
background-color: orange;
}
#login{//验证码部分首先隐藏
visibility: hidden;
}
#write,#yan{
width: 90px;
}
input{
width: 250px;
}
[type=button]{
font-weight: bold;
}
主要使用了onfocus,onkeyup,onblur,onclick事件
首先为了代码相对简单,先返回如下值
function $(str) { return document.getElementById(str); }
同时定义如下变量,用于统计字符数
function nameLen(str) {
return str.replace(/[^\x00-\xff]/g, 'yy').length //匹配双字节字符:[^\x00-\xff],将汉字转换成两个字母
}
先进行用户名验证:用户名可以使用数字、汉字、字母、下划线!
window.onload = function() {//主要使用onfocus,onkeyup,onblur,onclick事件
//用户名验证
var name_len = 0;
var reg = /[^\w\u4e00-\u9fa5]/g //[^\u4e00-\u9fa5]匹配所有汉字
$("Name").onfocus = function() {
$('login').style.visibility = "visible"; //显示验证码
$('warn').innerHTML = '<span id="warn">5-25个字符,一个汉字两个字符,可以使用数字、汉字、字母、下划线!</span>';
}
$("Name").onkeyup = function() {
if(reg.test(this.value)) {
$('warn').innerHTML = '<span>含有非法字符!</span>';
}
$('warn').style.visibility = "visible";
$('ziFu').style.visibility = "visible";
name_len = nameLen(this.value)
$('ziFu').innerHTML = name_len + '个字符';
if(name_len == 0) {
$('warn').style.visibility = "hidden";
}
}
$("Name").onblur = function() {
if($("Name").value == '') {
$('warn').innerHTML = '<span>不能为空!</span>';
} else if(name_len < 5) {
$('warn').innerHTML = '<span>用户名小于5个字符!</span>';
} else if(name_len > 25) {
$('warn').innerHTML = '<span>用户名大于5个字符!</span>';
} else {
$('warn').innerHTML = 'OK!';
}
}
效果如下:
身份证验证:没有考虑15位身份证的情况,也没有考虑所有地区,地区的验证仅对前两位进行了验证,同时出生日期没有考虑已去世的和未出生的,因为最后一位验证码,可以判断出身份证号码是否存在
//身份证号验证
$("Idcard").onfocus = function() {
$('warn2').innerHTML = '<span>请输入二代身份证号码!</span>';
}
$("Idcard").onblur = function() {
var regcard = /^((1[1-5])|(2[1-3])|(3[1-7])|(4[1-6])|(5[0-4])|(6[1-5])|([7-9]1)|(8[2]))\d{15}[0-9|X]{1}$/; //没有匹配所有地区
var y = (this.value.substring(6, 10)) * 1;
var m = (this.value.substring(10, 12)) * 1;
var d = (this.value.substring(12, 14)) * 1;
var mydate = new Date(y, m - 1, d);
if(this.value.length != 18) {//没有考虑15位号码身份证
$('warn2').innerHTML = '<span>长度有误,请输入18位身份证号码!</span>';
} else {
if(regcard.test(this.value)) {
if(mydate.getFullYear() != y || mydate.getMonth() != m - 1 || mydate.getDate() != d) {
$('warn2').innerHTML = '<span>出生年月有误,请重新输入!</span>';
} else { //验证最后一位校验码
var xiShu = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);//固定的
var yuShu = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
var sum = 0;
for(i = 0; i < xiShu.length; i++) {
sum += xiShu[i] * this.value.substring(i, i + 1)
}
var lastNum = yuShu[sum % 11]
if(lastNum == this.value.substring(17)) {
$('warn2').innerHTML = 'OK!';
} else {
$('warn2').innerHTML = '<span>有误,请重新输入!</span>'
}
}
} else {
$('warn2').innerHTML = '<span>出现非法字符,请重新输入!</span>';
}
}
}
效果:
密码验证:要求1、密码长度至少为6位,请使用数字、字母、下划线组合!2、密码必须有数字和字母,不能纯数字或字母!3、密码长度大于6,且含有数字、字母时强度为中!4、密码长度大于12,且含有数字、字母时为强度为高!5、密码强度显示根据输入密码变化,密码强度为弱,确认密码不能进行操作;
//密码验证
$("passWord").onfocus = function() {
$('warn3').innerHTML = '<span>密码长度至少为6位,请使用数字、字母、下划线组合!</span>'
}
$('passWord').onkeyup = function() {
var regCode = /[^\w]/g;
var regCode1 = /([0-9]+[a-zA-z]+)|([a-zA-z]+[0-9]+)/g //密码必须有数字和字母
if(regCode.test(this.value)) {
$('warn3').innerHTML = '<span>含有非法字符!</span>';
}
if(this.value.length > 6 && regCode1.test(this.value)) { //密码长度大于6,且含有数字、字母时强度为中
$('mid').style.backgroundColor = 'red';
$('ensure').removeAttribute('disabled');
$('warn4').style.visibility = 'visible';
$('warn4').innerHTML = '<span>请再次输入密码!</span>';
} else {
$('mid').style.backgroundColor = 'orange';
$('ensure').setAttribute('disabled', "disabled");
$('warn4').style.visibility = 'hidden';
}
if(this.value.length > 12) { //密码长度大于12,且含有数字、字母时为强度为高
$('high').style.backgroundColor = 'red';
} else {
$('high').style.backgroundColor = 'orange';
}
}
$('passWord').onblur = function() {
if($("passWord").value == '') {
$('warn3').innerHTML = '<span>不能为空!</span>';
} else if(this.value.length < 6) {
$('warn3').innerHTML = '<span>密码小于6个字符!</span>';
} else {
$('warn3').innerHTML = 'OK!';
}
}
效果:

确认密码:确认密码只需要判断两次输入的密码是否相同
//确认密码验证
$('ensure').onblur = function() {
if($('passWord').value==this.value) {
$('warn4').innerHTML = 'OK!';
} else {
$('warn4').innerHTML = '<span>两次输入密码不一样!</span>';
}
}


最后验证码验证:为了能够点击刷新,产生验证码函数单独写,在HTML文档中调用,同时页面页面加载时需调用一次
<tr id="login">
<td><p>验证码:</p></td>
<td>
<input type="text" name="" id="write" value=""/>
<input type="button" name="" id="yan" value="" disabled="disabled"/>
<button id="faSong" onclick="pro();Color ()">看不清</button>//调用
</td>
<td id="warn5"></td>
</tr>
产生验证码:使用数组,遍历数组产生随机6位验证码:
function pro() {//产生随机6位验证码
var code1='';
var code2='';
var arr = new Array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z',
'哎', '呦', '我', '去', '小', '鸡', '炖', '蘑', '菇', '天', '王', '盖', '地', '虎', '隔', '壁', '王', '叔', '叔');
for(var i = 0; i <6; i++) {
var element = Math.floor(Math.random() * arr.length);
code1 += arr[element];
}
$('yan').value = code1; //获取验证码
}
同样遍历数组,产生随机背景颜色和字体颜色,#+字母+数字构成所有颜色
function Color () {//产生随机颜色
var color='#';
var bgcolor='#';
var colorArr=new Array('0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F');
for (var j=0;j<6;j++) {
var colOne=Math.floor(Math.random() * colorArr.length);
var colTwo=Math.floor(Math.random() * colorArr.length);
color+=colorArr[colOne];
bgcolor+=colorArr[colTwo];
}
$('yan').style.color=color;
$('yan').style.backgroundColor=bgcolor;
}
这两个函数在页面加载时均需调用一次(除这两个函数在HTML中调用了外,其他函数均在window.onload下调用):
与确认密码一样,确认验证码也是判断两次的值是否相同
pro();//调用函数(产生验证码和颜色的函数)
Color ();
$('write').onfocus=function(){
//$('warn5').style.visibility='visible';
$('warn5').ininnerHTML='<span>请输入密码!</span>';
}
$('write').onblur=function(){
if(this.value==$('yan').value){
$('warn5').innerHTML='OK!';
}else{
$('warn5').innerHTML='<span>验证码不正确,请重新输入!</span>';
}
}
}


对于表单中的必填项,可以使用属性required="required"
代码贴出来,便于自己日后修改查找!
inform表单验证,正则表达式,用户名,身份证,密码,验证码的更多相关文章
- JavaScript 正则表单验证(用户名、密码、确认密码、手机号、座机号、身份证号)
1.关于JavaScript表单验证,如果使用双向绑定的前端js框架,会更容易的多.但是博主还是建议大家不要脱离源生js本身.因为源生js才是王道. 注意: a.代码中的错误提示可能会没有,在代码中找 ...
- JavaScript常用表单验证正则表达式(身份证、电话号码、邮编、日期、IP等)
身份证正则表达式 //身份证正则表达式(15位)isIDCard1=/^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/;//身份证正则表达式 ...
- JS中的表单验证+正则表达式
表单验证+正则表达式 一.非空验证 trim:去空格(去掉前后的空格),任何字符串都可以用这个方法.写法为:if(v.trim().length==0),表示如果去掉空格后的字符串的长度为0. < ...
- JavaScript 表单验证正则表达式大全
JavaScript 表单验证正则表达式大全[转载] 匹配中文字符的正则表达式: [u4e00-u9fa5] 评注:匹配中文还真是个头疼的事,有了这个表达式就好办了 匹配双字节字符(包括汉字在内):[ ...
- 登陆jq表单验证及jqcookie记住密码实例
<p><%@ page contentType="text/html; charset=utf-8"%> <%@taglib prefix=" ...
- 关于JS中的常用表单验证+正则表达式
一.非空验证 trim:去空格(去掉前后的空格),任何字符串都可以用这个方法.写法为:if(v.trim().length==0),表示如果去掉空格后的字符串的长度为0. <body> & ...
- jQuery表单验证正则表达式-简单
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="C ...
- JS表单验证类HTML代码实例
以前用的比较多的一个JS表单验证类,对于个人来说已经够用了,有兴趣的可以在此基础上扩展成ajax版本.本表单验证类囊括了密码验证.英文4~10个 字符验证. 中文非空验证.大于10小于100的数字.浮 ...
- 前端表单验证常用的15个JS正则表达式
在表单验证中,使用正则表达式来验证正确与否是一个很频繁的操作,本文收集整理了15个常用的javaScript正则表达式,其中包括用户名.密码强度.整数.数字.电子邮件地址(Email).手机号码.身份 ...
随机推荐
- 小白该怎么学《马哥Linux从入门到精通》
首先,必须说明我已经不是小白啦~现在的我在国内某独角兽担任运维工程师,带着一个四人小团队,在运维方面也算是有些心得,勉强过来回答一下这个问题,就算抛砖引玉了. 所有人都是从小白阶段过来的,我=也经历过 ...
- 2060: [Usaco2010 Nov]Visiting Cows 拜访奶牛
2060: [Usaco2010 Nov]Visiting Cows 拜访奶牛 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 252 Solved: 1 ...
- Spring Boot HTTP over JSON 的错误码异常处理
摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢! “年轻人不要怕表现,要敢于出来表现,但还是那句话,要有正确的度,你的表现是分析问题和解决问题的能 ...
- Robot Framework 使用笔记
条件表达式: Run Keyword If 表达式 执行动作 ... ELSE IF 表达式 执行动作 ... ELSE 执行动作 基础格式见上表,下面是我遇到的坑: 表达式:判断字符串变量是 ...
- iOS多线程——同步异步串行并行
串行并行异步同步的概念很容易让人混淆,关于这几个概念我在第一篇GCD中有解释,但是还不够清晰,所以这里重写一篇博客专门对这几个概念进行区分: 先说一下队列和任务: (1)队列分为串行和并行,任务的执行 ...
- 享受release版本发布的好处的同时也应该警惕release可能给你引入一些莫名其妙的大bug
一般我们发布项目的时候通常都会采用release版本,因为release会在jit层面对我们的il代码进行了优化,比如在迭代和内存操作的性能提升方面,废话不多说, 我先用一个简单的“冒泡排序”体验下r ...
- 解锁redis锁的正确姿势
解锁redis锁的正确姿势 redis是php的好朋友,在php写业务过程中,有时候会使用到锁的概念,同时只能有一个人可以操作某个行为.这个时候我们就要用到锁.锁的方式有好几种,php不能在内存中用锁 ...
- 张高兴的 UWP 开发笔记:定制 ContentDialog 样式
我需要一个背景透明的 ContentDialog,像下图一样.如何定制?写了一个简单的示例(https://github.com/ZhangGaoxing/uwp-demo/tree/master/C ...
- javascript中常用的
1.javascript中构造equals().trim()方法并应用 String.prototype.Trim = function() { return this.replace(/(^\s*) ...
- 深入理解CPU和异构计算芯片GPU/FPGA/ASIC (上篇)
王玉伟,腾讯TEG架构平台部平台开发中心基础研发组资深工程师,专注于为数据中心提供高效的异构加速云解决方案.目前,FPGA已在腾讯海量图片处理以及检测领域已规模上线. 随着互联网用户的快速增长,数据体 ...