JS正則表達式驗證密碼強度
更新時間:2020年03月18日 13:54:05 作者:夏沐_lk
這篇文章主要為大家詳細介紹了JS正則表達式驗證密碼強度,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了JS正則表達式驗證密碼強度的具體代碼,供大家參考,具體內(nèi)容如下
代碼1:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<style type="text/css">
#dv{
width: 300px;
height:200px;
position: absolute;
left:300px;
top:100px;
}
.strengthLv0 {
height: 6px;
width: 120px;
border: 1px solid #ccc;
padding: 2px;
}
.strengthLv1 {
background: red;
height: 6px;
width: 40px;
border: 1px solid #ccc;
padding: 2px;
}
.strengthLv2 {
background: orange;
height: 6px;
width: 80px;
border: 1px solid #ccc;
padding: 2px;
}
.strengthLv3 {
background: green;
height: 6px;
width: 120px;
border: 1px solid #ccc;
padding: 2px;
}
</style>
<body>
<div id="dv">
<label for="pwd">密碼</label>
<input type="text" id="pwd" maxlength="16"><!--課外話題-->
<div>
<em>密碼強度:</em>
<em id="strength"></em>
<div id="strengthLevel" class="strengthLv0"></div>
</div>
</div>
<script src="common.js"></script>
<script>
/*
*
* 密碼: 數(shù)字,字母,特殊符號
*
* 密碼: 只有數(shù)字- 或者是只有字母,或者是只有特殊符號---1級---弱
* 兩兩組合: 數(shù)字和字母, 數(shù)字和特殊符號, 字母和特殊符號 -----2級----中
* 三者都有: 數(shù)字和字母和特殊符號------3級-----強
*
* */
//獲取文本框注冊鍵盤抬起事件
my$("pwd").onkeyup=function () {
//每次鍵盤抬起都要獲取文本框中的內(nèi)容,驗證文本框中有什么東西,得到一個級別,然后下面的div顯示對應(yīng)的顏色
//如果密碼的長度是小于6的,沒有必要判斷
if(this.value.length>=6){
var lvl=getLvl(this.value);
if(lvl==1){
//弱
my$("strengthLevel").className="strengthLv1";
}else if(lvl==2){
my$("strengthLevel").className="strengthLv2";
}else if(lvl==3){
my$("strengthLevel").className="strengthLv3";
}else{
my$("strengthLevel").className="strengthLv0";
}
}else{
my$("strengthLevel").className="strengthLv0";
}
};
//給我密碼,我返回對應(yīng)的級別
function getLvl(pwd) {
var lvl=0;//默認是0級
//密碼中是否有數(shù)字,或者是字母,或者是特殊符號
if(/[0-9]/.test(pwd)){
lvl++;
}
//判斷密碼中有沒有字母
if(/[a-zA-Z]/.test(pwd)){
lvl++;
}
//判斷密碼中有沒有特殊符號
if(/[^0-9a-zA-Z_]/.test(pwd)){
lvl++;
}
return lvl;//1 3
}
</script>
</body>
</html>
優(yōu)化代碼2:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<style type="text/css">
#dv{
width: 300px;
height:200px;
position: absolute;
left:300px;
top:100px;
}
.strengthLv0 {
height: 6px;
width: 120px;
border: 1px solid #ccc;
padding: 2px;
}
.strengthLv1 {
background: red;
height: 6px;
width: 40px;
border: 1px solid #ccc;
padding: 2px;
}
.strengthLv2 {
background: orange;
height: 6px;
width: 80px;
border: 1px solid #ccc;
padding: 2px;
}
.strengthLv3 {
background: green;
height: 6px;
width: 120px;
border: 1px solid #ccc;
padding: 2px;
}
</style>
<body>
<div id="dv">
<label for="pwd">密碼</label>
<input type="text" id="pwd" maxlength="16"><!--課外話題-->
<div>
<em>密碼強度:</em>
<em id="strength"></em>
<div id="strengthLevel" class="strengthLv0"></div>
</div>
</div>
<script src="common.js"></script>
<script>
//獲取文本框注冊鍵盤抬起事件
my$("pwd").onkeyup=function () {
//每次鍵盤抬起都要獲取文本框中的內(nèi)容,驗證文本框中有什么東西,得到一個級別,然后下面的div顯示對應(yīng)的顏色
//如果密碼的長度是小于6的,沒有必要判斷
// if(this.value.length>=6){
// var lvl= getLvl(this.value);
// my$("strengthLevel").className="strengthLv"+lvl;
// }else{
// my$("strengthLevel").className="strengthLv0";
// }
my$("strengthLevel").className="strengthLv"+(this.value.length>=6?getLvl(this.value) :0);
};
//給我密碼,我返回對應(yīng)的級別
function getLvl(pwd) {
var lvl=0;//默認是0級
//密碼中是否有數(shù)字,或者是字母,或者是特殊符號
if(/[0-9]/.test(pwd)){
lvl++;
}
//判斷密碼中有沒有字母
if(/[a-zA-Z]/.test(pwd)){
lvl++;
}
//判斷密碼中有沒有特殊符號
if(/[^0-9a-zA-Z_]/.test(pwd)){
lvl++;
}
return lvl;//最小的值是1,最大值是3
}
</script>
</body>
</html>
common.js
/**
* 獲取指定標(biāo)簽對象
* @param id 標(biāo)簽的id屬性值
* @returns {Element}根據(jù)id屬性值返回指定標(biāo)簽對象
*/
function my$(id) {
return document.getElementById(id);
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript函數(shù)及其prototype詳解
這篇文章主要介紹了JavaScript函數(shù)及其prototype詳解的相關(guān)資料,需要的朋友可以參考下2023-03-03
layui添加動態(tài)菜單與選項卡 AJAX請求的例子
今天小編就為大家分享一篇layui添加動態(tài)菜單與選項卡 AJAX請求的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
教你修改element-ui源碼給el-dialog添加全屏功能
el-dialog組件提供了fullscreen功能,但是無法滿足業(yè)務(wù)需求。系統(tǒng)使用了許多dialog,不方便重新封裝dialog組件,故直接對源碼進行修改,這篇文章主要介紹了修改element-ui源碼給el-dialog添加全屏功能,需要的朋友可以參考下2022-11-11
Javascript腳本獲取form和input內(nèi)容的方法(兩種方法)
隨著js的發(fā)展,許多的網(wǎng)頁數(shù)據(jù)處理完全可以由js腳本解決,而不需要發(fā)送到服務(wù)器,這里分享兩種Javascript腳本獲取form和input內(nèi)容的方法,感興趣的朋友跟隨小編一起看看吧2023-05-05
JavaScript類型檢測之typeof 和 instanceof 的缺陷與優(yōu)化
在javascript中,typeof 和 instanceof 是用來判斷數(shù)據(jù)類型比較通用的兩個方法,這篇文章的目的是通過對這兩個方法介紹來分析其存在的不足并提出優(yōu)化方案2016-01-01
js函數(shù)定時器實現(xiàn)定時讀取系統(tǒng)實時連接數(shù)
這篇文章主要介紹了使用js函數(shù)定時器實現(xiàn)定時讀取系統(tǒng)實時連接數(shù),需要的朋友可以參考下2014-04-04

