javascript實(shí)現(xiàn)密碼強(qiáng)度顯示
密碼強(qiáng)度顯示和中文強(qiáng)弱顯示
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'a.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<style type="text/css">
* {margin:0px;padding:0px;}
.J_PasswordStatus{padding-bottom:0px;height:18px;}
.status-bar{margin:0px;display:inline-block;width:80px;height:5px;padding:1px;border:1px solid #42BF26;background-color:white;vertical-align:middle;font-size:0;}
.status-bar span{background-color:#42BF26;height:5px;display:inline-block;}
</style>
</head>
<body>
<input type="password" id="pwd1" style="float:left;margin-top:5px;" onkeyup="checkPassword();"/>
<div id="p_PasswordStatus" class="J_PasswordStatus"
style="display: none; width: 300px;">
<span class="trigger">密碼強(qiáng)度: </span>
<span class="status-bar" style="text-indent: 0px;">
<span style="line-height: 5px;"> </span>
</span>
<span class="status-result"></span>
</div>
</body>
</html>
<script type="text/javascript" src="jquery-1.7.2.min.js"></script>
<script type="text/javascript">
function checkPassword(){
var pwd = $("#pwd1").val();
gPasswdStatus(pwd,'p_PasswordStatus');
}
function gPasswdStatus(value,id){
var status = $("#"+id);
var result = $("#"+id).find(".status-result")[0];
var bar = $("#"+id).find(".status-bar span");
if (value === "") {
status.css("display","none");
} else {
var score = gCheckPassword(value);
bar.css("width",score + "%");
var resultDesp = gGetResultDesp(score);
result.innerHTML = resultDesp;
status.css("display","block");
}
}
/**
* 檢驗(yàn)密碼強(qiáng)度并返回得分
*
* @param {}
* password
* @return {Number}
*/
function gCheckPassword(password) {
var _score = 0;
if (!password) {
return 0
}
if (password.length <= 4) {
_score += 5
} else {
if (password.length >= 5 && password.length <= 7) {
_score += 10
} else {
if (password.length >= 8) {
_score += 25
}
}
}
var _UpperCount = (password.match(/[A-Z]/g) || []).length;
var _LowerCount = (password.match(/[a-z]/g) || []).length;
var _LowerUpperCount = _UpperCount + _LowerCount;
if (_UpperCount && _LowerCount) {
_score += 20
} else {
if (_UpperCount || _LowerCount) {
_score += 10
}
}
var _NumberCount = (password.match(/[\d]/g, "") || []).length;
if (_NumberCount > 0 && _NumberCount <= 2) {
_score += 10
} else {
if (_NumberCount >= 3) {
_score += 20
}
}
var _CharacterCount = (password.match(/[!@#$%^&*?_\.\-~]/g) || []).length;
if (_CharacterCount == 1) {
_score += 10
} else {
if (_CharacterCount > 1) {
_score += 25
}
}
if (_NumberCount && (_UpperCount && _LowerCount)
&& _CharacterCount) {
_score += 5
} else {
if (_NumberCount && _LowerUpperCount && _CharacterCount) {
_score += 3
} else {
if (_NumberCount && _LowerUpperCount) {
_score += 2
}
}
}
return _score
}
/**
* 根據(jù)密碼強(qiáng)度得分返回密碼強(qiáng)弱度中文提示
*
* @param {}
* score
* @return {String}
*/
function gGetResultDesp(score) {
if (score <= 5) {
return "\u592a\u77ed"
} else {
if (score > 5 && score < 20) {
return "\u5f31"
} else {
if (score >= 20 && score < 60) {
return "\u4e2d"
} else {
if (score >= 60) {
return "\u5f3a"
} else {
return ""
}
}
}
}
}
</script>
以上所述就是本文給大家分享的全部內(nèi)容了,希望對大家熟練掌握javascript能夠有所幫助。
- JS 密碼強(qiáng)度驗(yàn)證(兼容IE,火狐,谷歌)
- js檢驗(yàn)密碼強(qiáng)度(低中高)附圖
- Js密碼強(qiáng)度實(shí)時(shí)驗(yàn)證代碼
- javascript密碼強(qiáng)度校驗(yàn)代碼(兩種方法)
- JavaScript 密碼強(qiáng)度判斷代碼
- js檢測用戶輸入密碼強(qiáng)度
- js密碼強(qiáng)度實(shí)時(shí)檢測代碼
- JavaScript判斷密碼強(qiáng)度(自寫代碼)
- js密碼強(qiáng)度校驗(yàn)
- js實(shí)現(xiàn)密碼強(qiáng)度檢測【附示例】
- js正則表達(dá)式驗(yàn)證密碼強(qiáng)度【推薦】
- js密碼強(qiáng)度檢測
- JavaScript動(dòng)態(tài)檢驗(yàn)密碼強(qiáng)度的實(shí)現(xiàn)方法
- JS實(shí)現(xiàn)的四級密碼強(qiáng)度檢測功能示例
相關(guān)文章
JavaScript中cookie工具函數(shù)封裝的示例代碼
這篇文章給大家主要介紹了JavaScript中cookie工具函數(shù)的封裝,文中給出了詳細(xì)的實(shí)現(xiàn)步驟和示例代碼,相信會對大家的理解很有幫助,有需要的朋友們下面來一起看看吧。2016-10-10JavaScript獲取數(shù)據(jù)類型的方法詳解
這篇文章給大家介紹了JavaScript獲取數(shù)據(jù)類型的方法,文中所介紹的所有知識點(diǎn)、代碼示例以及提供的解決方案,均不考慮?IE?瀏覽器,僅支持最新版本的?Chrome、Firefox、Edge?和?Safari?瀏覽器,需要的朋友可以參考下2024-02-02js實(shí)現(xiàn)仿阿里巴巴城市選擇框效果實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)仿阿里巴巴城市選擇框效果,實(shí)例分析了javascript結(jié)合css與數(shù)組實(shí)現(xiàn)城市選擇框的方法,需要的朋友可以參考下2015-06-06javascript 響應(yīng)鍵盤特定按鍵(只響應(yīng)數(shù)字鍵)
響應(yīng)鍵盤特定按鍵(只響應(yīng)數(shù)字鍵),大家可以看看思路。2009-03-03原生js實(shí)現(xiàn)二級聯(lián)動(dòng)菜單
這篇文章主要為大家詳細(xì)介紹了原生js實(shí)現(xiàn)二級聯(lián)動(dòng)菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11JS組件中bootstrap multiselect兩大組件較量
這篇文章主要介紹了JS組件中bootstrap multiselect兩大組件,兩者之間的較量,優(yōu)缺點(diǎn)比較,感興趣的小伙伴們可以參考一下2016-01-01javascript實(shí)現(xiàn)延時(shí)顯示提示框特效代碼
本文給大家分享的是javascript通過setTimeout實(shí)現(xiàn)延時(shí)顯示提示框的特效代碼,效果非常棒,這里推薦給大家2016-04-04layui上傳圖片到服務(wù)器的非項(xiàng)目目錄下的方法
今天小編就為大家分享一篇layui上傳圖片到服務(wù)器的非項(xiàng)目目錄下的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09