JavaScript:表单及正则表达式验证

今天我要介绍的是在JavaScript中关于表单验证内容的知识点介绍:

关于表单验证,我接下来则直接将内容以及效果显示出来并作注解,这样可以清晰看见这个表达验证的妙用:

javascript 复制代码
<form id="ff" action="https://www.baidu.com">
			<h1>用户登录</h1>
			账号:<input type="text" id="zh" /> <span></span> <br />
			密码:<input type="password" id="mm" /><span></span> <br />
			<Button>登录</Button>
		</form>

效果:

**注:可以看到这是一个非常经典的登录界面的制作,**下面我会逐一介绍他们内部的方法使用以及代码显示的效果;

onclick: 点击事件 //ondblclick: 双击事件 // onsubmit: 表单提交事件 // onblur: 失去焦点事件 // onfocus: 获取焦点事件。

注: 这是事件点击使用的方法代码;

表单提交的代码演示:

javascript 复制代码
document.getElementById('ff(自定义)').onsubmit = function() {
				console.log('触发了onsubmit');
				// 获取表单中的账号和密码
				let zh = document.getElementById("zh").value;
				let mm = document.getElementById("mm").value;
				// 判断账号及密码是否为空
				if (zh.length == 0 || mm.length == 0) {
					alert('请输入正确的账号或密码')
                     // 自定义弹出框
					document.querySelector('.mask').style.display = "block";
					return false;
				}
				// 以下结果为true 表允许表单提
				//交到指定页面,反之则不能,且只能实现所输入的结果
				return true;
			}

:**{ return false }为阻止表单提交,但如果整体代码无错,{ return true }**则通过,提交表单。

效果:

账号和密码获取/失去焦点演示:

javascript 复制代码
         // 账号获取焦点事件
			document.getElementById('zh').onfocus = function() {
				// let = zh = this.value;
				this.nextElementSibling.innerHTML = "";
			}
			// 账号失去焦点事件
			document.getElementById('zh').onblur = function() {
				let = zh = this.value;
				let f = zh.length == 0;
				console.log(zh);
				this.nextElementSibling.innerHTML = f ? "×" : "√";
				// this.nextElementSibling.style.display=f?"block":"none";
 			}
            // 密码获取焦点事件
			document.getElementById('mm').onfocus = function() {
				// let = zh = this.value;
				this.nextElementSibling.innerHTML = "";
			}
			// 密码失去焦点事件
			document.getElementById('mm').onblur = function() {
				let = zh = this.value;
				let f = zh.length == 0;
				console.log(zh);
				this.nextElementSibling.innerHTML = f ? "×" : "√";
				// this.nextElementSibling.style.display=f?"block":"none";
			}

注:注意看账号和密码的代码格式内容,两者设置的自定义不同,并非全部都是一样

效果:

密码:

注:当内容存在焦点时则有判断,有内容则成立,无内容则错误,不成立,无法进行表单提交

正则表达式:

<!-- 正则表达式是用于对数据格式进行判断 -->

<!-- 定义正则表达式: var rex = /^\d$\(\d表0-0的数字) -->

<!-- 1.内容(以\开头) -->

<!-- \d:表0-9的数字 -->

<!-- \w:表0-9a-zA-Z_ --> (非:不是,表示否定之意,这里注意

<!-- \D:表非0-9的数字 -->

<!-- \W:表非0-9a-zA-Z -->

<!-- .表任意一个单个字符 -->

<!-- 2.字符出现速度 -->

<!-- ?表0 or 一次 -->

<!-- +表一次或者多次 -->

<!-- *表0此或多次 -->

<!-- \d{5}表五个数字 -->

<!-- \d{5,10}表至低五个,至高十个 -->

例:

javascript 复制代码
// 例一:
			var rex = /^[A-Z]{1}\w{5,11}$/
			 console.log(rex.test('Zking1234'));

效果:

注:开头小写不成立,不满足;

例:

javascript 复制代码
// // QQ号案例
			[email protected]
			 var rex1 = /^\d{5,12}@qq.com$/
			 console.log(rex.test('[email protected]'));

注: 后面的 @qq.com 为固定值

以正则表达式为方法的登录界面:

注:(效果与表单验证同理,但是在其基础上用正则表达式的方式进行使用。)

javascript 复制代码
<form id="ff" action="">
			<h1>用户登录</h1>
			账号:<input type="text" id ="zh" /> <span></span> <br />
			密码:<input type="text" id="mm" /><span></span> <br />
			<Button>登录</Button>
		</form>
		<input type="text" id ="mm1"  /><span></span>

document.getElementById("ff").onsubmit=function(){
				// 定义账号的验证规则
				var rex1 = /^[a-z]{5,10}$/
				// 定义密码 
				var rex2 = /^[a-z0-9A-Z.]{5,10}$/
				
				var username = rex1.test(zh.value);
				console.log(usernam);
				if(username){
					zh.nextElementSibling.style="color:blue";
					zh.nextElementSibling.innerHTML="对";
				}else{
					zh.nextElementSibling.style="color:green";
					zh.nextElementSibling.innerHTML="错";
				}
				var password = rex2.test(mm.value);
				console.log(password);
				if(password){
					mm.nextElementSibling.style="color:blue";
					mm.nextElementSibling.innerHTML="对";
				}else{
					mm.nextElementSibling.style="color:green";
					mm.nextElementSibling.innerHTML="错";
				}
				return username&&password;
			}

注:关键点:return username&&password;

效果:

注:未输入内容时的效果;

注:输入内容与为输入内容时的对照。

密码安全级别强度验证:

javascript 复制代码
document.getElementById('mm1').onkeyup=function(){
			let c = 0;
			var rex1 = /^.*\d.*$/;  //包含数字
			var rex2 = /^.*[a-z].*$/; //包含字母
			var rex3 = /^.*[A-Z].*$/; //包含大写字母
			var rex4 = /^.*[@.].*$/; //包含特殊符号
			let m = this.value;
			if(rex1.test(m)){
				c++;
			}
			if(rex2.test(m)){
				c++;
			}
			if(rex3.test(m)){
				c++;
			}
			if(rex4.test(m)){
				c++;
			}
			let arr=['弱','中等','强','超强']
			if(m.length==0){
				this.nextElementSibling.innerHTML="";
			}else{
				this.nextElementSibling.innerHTML=arr[c-1];
			}
			
		}

效果:

释义

javascript 复制代码
let arr=['弱','中等','强','超强']
			if(m.length==0){
				this.nextElementSibling.innerHTML="";
			}else{
				this.nextElementSibling.innerHTML=arr[c-1];   《==
			}

注: c-1由强至弱反向,由弱至强正向,

**总结:**希望本篇有关于JavaScript表单验证和正则表达式的知识点内容能对你带来一定的帮助,同时非常感谢各位大佬们的点赞与支持,咱们下一篇不见不散。

相关推荐
FuckPatience几秒前
关于C#项目中 服务层使用接口的问题
java·开发语言·c#
编程轨迹_1 小时前
使用 Spring 和 Redis 创建处理敏感数据的服务
java·开发语言·restful
赵和范1 小时前
C++:书架
开发语言·c++·算法
boooo_hhh1 小时前
第J7周:对于ResNeXt-50算法的思考
开发语言·python·深度学习
春天姐姐2 小时前
vue知识点总结 依赖注入 动态组件 异步加载
前端·javascript·vue.js
LSL666_2 小时前
Java——多态
java·开发语言·多态·内存图
麓殇⊙2 小时前
CurrentHashMap的整体系统介绍及Java内存模型(JVM)介绍
java·开发语言·jvm
LSL666_3 小时前
Java——包装类
java·开发语言·包装类
yasuniko3 小时前
C++线程库
开发语言·c++
@老蝴3 小时前
C语言—指针2
c语言·开发语言