Javascript正則表達(dá)式實(shí)現(xiàn)輸入框驗(yàn)證信息功能實(shí)例
1.了解正則表達(dá)式可以:
- 測(cè)試字符串的某個(gè)模式。例如,可以對(duì)一個(gè)輸入字符串進(jìn)行測(cè)試,看在該字符串是否存在一個(gè)電話號(hào)碼模式或一個(gè)信用卡號(hào)碼模式。這稱為數(shù)據(jù)有效性驗(yàn)證
- 替換文本??梢栽谖臋n中使用一個(gè)正則表達(dá)式來標(biāo)識(shí)特定文字,然后可以全部將其刪除,或者替換為別的文字
- 根據(jù)模式匹配從字符串中提取一個(gè)子字符串??梢杂脕碓谖谋净蜉斎胱侄沃胁檎姨囟ㄎ淖?/li>
- 根據(jù)模式匹配從字符串中提取一個(gè)子字符串??梢杂脕碓谖谋净蜉斎胱侄沃胁檎姨囟ㄎ淖?/li>
正則表達(dá)式語法
一個(gè)正則表達(dá)式就是由普通字符(例如字符 a 到 z)以及特殊字符(稱為元字符)組成的文字模式。該模式描述在查找文字主體時(shí)待匹配的一個(gè)或多個(gè)字符串。正則表達(dá)式作為一個(gè)模板,將某個(gè)字符模式與所搜索的字符串進(jìn)行匹配。
2.正則表達(dá)式驗(yàn)證輸入框信息實(shí)現(xiàn)以下功能
- 如果輸入正確則提示正確的信息顯示綠色,小圖標(biāo)變化
- 如果輸入的不是6~18位密碼則提示錯(cuò)誤的信息顯示紅色,小圖標(biāo)變化
效果圖如下
代碼如下
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <title>密碼框驗(yàn)證信息</title> <style type="text/css"> * { padding: 0; margin: 0; } div { width: 800px; height: 30px; margin: 20px auto; } .info { /* background-color: #41b916; */ width: 60px; height: 100%; text-align: right; display: inline-block; } .ipt { width: 200px; height: 100%; line-height: 30px; padding: 5px; box-sizing: border-box; } .message { display: inline-block; color: #999; background: url(img/提示.png) no-repeat left center; font-size: 12px; padding-left: 24px; height: 100%; line-height: 30px; text-align: center; } .wrong { color: #ee2c13; background-image: url(img/關(guān)閉圓.png); } .right { color: #41b916; background-image: url(img/選中圓.png); } </style> <script type="text/javascript"> window.onload = function() { //獲取元素 var realname = document.querySelector('#realname'); var realnamemsg = document.querySelector('#realnamemsg'); var psd = document.querySelector('#psd') var psdmsg = document.querySelector('#psdmsg') var email = document.querySelector('#email') var emailmsg = document.querySelector('#emailmsg') var phone = document.querySelector('#phone') var phonemsg = document.querySelector('#phonemsg') //驗(yàn)證用戶名 realname.onblur = function() { var value = realname.value; var reg = /^[a-zA-Z][a-zA-Z0-9_]{4,15}$/; //帳號(hào)是否合法(字母開頭,允許5-16字節(jié),允許字母數(shù)字下劃線) var flag = reg.test(value); if (!flag) { realnamemsg.className = "message wrong"; realnamemsg.innerHTML = "請(qǐng)輸入正確的用戶名" } else { realnamemsg.className = "message right"; realnamemsg.innerHTML = "用戶名輸入正確" } } //驗(yàn)證密碼 psd.onblur = function() { var value = psd.value; var reg = /^[a-zA-Z]\w{5,17}$/; //密碼(以字母開頭,長度在6~18之間,只能包含字母、數(shù)字和下劃線) var flag = reg.test(value); if (!flag) { psdmsg.className = "message wrong"; psdmsg.innerHTML = "請(qǐng)輸入正確的密碼" } else { psdmsg.className = "message right"; psdmsg.innerHTML = "密碼正確" } } //驗(yàn)證郵箱 email.onblur = function() { var value = email.value; var reg = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/; //驗(yàn)證郵箱 var flag = reg.test(value); if (!flag) { emailmsg.className = "message wrong"; emailmsg.innerHTML = "請(qǐng)輸入正確的郵箱號(hào)" } else { emailmsg.className = "message right"; emailmsg.innerHTML = "郵箱正確" } } //驗(yàn)證手機(jī)號(hào) phone.onblur = function() { var value = phone.value; var reg = /^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$/; //驗(yàn)證手機(jī)號(hào)碼 var flag = reg.test(value); if (!flag) { phonemsg.className = "message wrong"; phonemsg.innerHTML = "請(qǐng)輸入正確的手機(jī)號(hào)碼" } else { phonemsg.className = "message right"; phonemsg.innerHTML = "號(hào)碼正確" } } } </script> </head> <body> <div> <p class="info">用戶名</p> <input type="text" class="ipt" id="realname"> <p class="message" id="realnamemsg">請(qǐng)輸入6~10位用戶名,以字母開頭,允許字母數(shù)字下劃線</p> </div> <div> <p class="info">密碼</p> <input type="password" class="ipt" id="psd"> <p class="message" id="psdmsg">密碼以字母開頭,長度在6~18之間,只能包含字母、數(shù)字和下劃線</p> </div> <div> <p class="info">郵箱</p> <input type="email" class="ipt" id="email"> <p class="message" id="emailmsg">請(qǐng)輸入正確的郵箱賬號(hào)</p> </div> <div> <p class="info">手機(jī)號(hào)</p> <input type="text" class="ipt" id="phone"> <p class="message" id="phonemsg">請(qǐng)輸入正確的手機(jī)號(hào)碼</p> </div> </body> </html>
附:常用方法
1.RegExp():構(gòu)造函數(shù),有兩個(gè)參數(shù),第一個(gè)參數(shù)是正則表達(dá)式,第二個(gè)參數(shù)是表示使用什么樣的模式來匹配(可省略)。
2.exec():字符串中執(zhí)行查找匹配的RegExp方法,它返回一個(gè)數(shù)組(未匹配到則返回null)。該方法有一個(gè)參數(shù),表示要匹配的字符串。
var res = RegExp(“[0-9]{2}”); var regex = res.exec(1234567);//[“12”, index: 0, input: “1234567”]
3.test():字符串中是否匹配的RegExp方法,返回true或false。該方法有一個(gè)參數(shù),表示要匹配的字符串。
var res = new RegExp(“[0-9]{2}”); var result = res.test(1234567);
總結(jié)
到此這篇關(guān)于Javascript正則表達(dá)式實(shí)現(xiàn)輸入框驗(yàn)證信息功能的文章就介紹到這了,更多相關(guān)js正則表達(dá)式輸入框驗(yàn)證信息內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript實(shí)現(xiàn)點(diǎn)擊產(chǎn)生隨機(jī)圖形
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)點(diǎn)擊產(chǎn)生隨機(jī)圖形,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-01-01JS實(shí)現(xiàn)保留n位小數(shù)的四舍五入問題示例
這篇文章主要介紹了JS實(shí)現(xiàn)保留n位小數(shù)的四舍五入問題,結(jié)合完整實(shí)例形式分析了javascript針對(duì)小數(shù)四舍五入操作技巧,需要的朋友可以參考下2016-08-08一個(gè)最簡(jiǎn)單的級(jí)聯(lián)下拉菜單
一個(gè)最簡(jiǎn)單的級(jí)聯(lián)下拉菜單...2006-12-12這應(yīng)該是最詳細(xì)的響應(yīng)式系統(tǒng)講解了
這篇文章主要介紹了這應(yīng)該是最詳細(xì)的響應(yīng)式系統(tǒng)講解了,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07使用JavaScript計(jì)算前一天和后一天的思路詳解
這篇文章主要介紹了使用JavaScript計(jì)算前一天和后一天的思路,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12dateformat.js超輕量級(jí)的JS日期處理庫的使用
dateformat.js 是一個(gè)非常簡(jiǎn)潔、輕量級(jí)、不到 5kb 的很簡(jiǎn)潔的 Javascript 庫,本文主要介紹了dateformat.js超輕量級(jí)的JS日期處理庫的使用,感興趣的可以了解一下2023-12-12