本篇內(nèi)容介紹了“如何使用JavaScript實現(xiàn)表單驗證”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
十載的鐵西網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。全網(wǎng)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整鐵西建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)公司從事“鐵西網(wǎng)站設(shè)計”,“鐵西網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。
在Web項目開發(fā)中,經(jīng)常會看到表單驗證的功能。例如,用戶注冊、用戶登錄等,需要對用戶填寫的內(nèi)容進行驗證。接下來,小編帶著大家一起來實現(xiàn)表單驗證的用戶名、密碼、性別、手機號碼、郵箱驗證的功能。
開發(fā)工具:HBuilderX
瀏覽器:Google Chrome瀏覽器
1.了解什么是正則表達式。
2.掌握正則表達式的語法。
3.學會應(yīng)用正則表達式。
HTML
<div class="box"> <div class="box-head"><h2>歡迎注冊</h2><p style="font-size: 15px;">已有賬號?<a href="#" style="color: #3366D4;">登錄</a></p></div> <div class="box-body"> <form id="register" > <table> <tr> <th>用戶名稱:</th> <td> <input type="text" id="user" name="user" placeholder="長度4-12位,英文大小寫字母"> </td> <td> <div></div> </td> </tr> <tr> <th>密碼:</th> <td><input type="password" id="passWord" name="passWord" placeholder="長度6-20位,大小寫字母、數(shù)字或下劃線"></td> <td> <div></div> </td> </tr> <tr> <th>確認密碼:</th> <td><input type="password" id="repassWord" name="repassWord" placeholder="請再次輸入密碼進行確認"></td> <td> <div></div> </td> </tr> <tr> <th>性別:</th> <td><input type="radio" id="Male" name="sex" value="1"/><label for="Male">男</label> <input type="radio" id="Female" name="sex" value="0"/><label for="Female">女</label></td> <td> <div></div> </td> </tr> <tr> <th>手機號碼:</th> <td><input type="text" id="telephone" name="telephone" placeholder="13、14、15、17、18開頭的11位手機號"></td> <td> <div></div> </td> </tr> <tr> <th>電子郵箱:</th> <td><input type="text" id="email" name="email" placeholder="用戶名@域名(域名后綴至少2個字符)"></td> <td> <div></div> </td> </tr> </table> <div style="display: flex;justify-content: center;"> <button type="submit" id="btn_ok">注冊</button> </div> </form> </div> </div>
在上面代碼中,使用table標簽元素表示定義一個HTML表格,tr表示表格中的行,td表示表格中的列。name表示獲取對應(yīng)文本的正則規(guī)則驗證,placeholder屬性表示提示信息。
1.添加事件
// 獲取所有input框 var inputs = document.getElementsByTagName('input'); // 為每個input框添加失去焦點事件 for (var i = 0; i < inputs.length; i++) { inputs[i].onblur = inputBlur; }
在上面代碼中,首先是獲取用戶注冊頁面所有的input元素,為每個input框添加失去焦點事件,利用for循環(huán)來添加事件處理函數(shù)inputBlur()。
2.寫inputBlur()事件處理函數(shù),該函數(shù)主要用于獲取相應(yīng)input元素的驗證規(guī)則和提示信息,用戶輸入的內(nèi)容進行檢驗,之后,把檢驗的結(jié)果顯示在HTML頁面中,代碼如下所示:
function inputBlur() { // 獲取輸入框的name值、value值、框中的提示信息 var name = this.name; var val = this.value; var display = this.placeholder; var display_obj = this.parentNode.parentNode.children[2].children[0]; //顯示提示信息 //去掉兩端空格 val = val.trim(); //判斷內(nèi)容為空,顯示提示信息 if (!val) { error(display_obj, '輸入框內(nèi)容不能為空'); return false; } //獲取正則匹配規(guī)則和提示信息 var reg_msg = getRegMsg(name, display); //檢測是否正則匹配 if (reg_msg['reg'].test(val)) { // 匹配成功 success(display_obj, reg_msg['msg']['success']); } else { // 匹配失敗 error(display_obj, reg_msg['msg']['error']); } }
在上面代碼中,變量名name、val、tips分別是獲取input元素中的name、value、placeholder屬性的值。
變量名tips_obj用于當input元素失去焦點的時候,顯示提示信息。
val.trim()方法主要是用戶輸入內(nèi)容中兩端空格。
getRegMsg()自定義函數(shù)用來獲取文本框中相對應(yīng)的正則和提示信息。
test()方法用于獲取當前input框輸入的內(nèi)容是否是正則匹配的模式,如果是則返回true,顯示驗證成功的信息。如果不是則返回false,顯示錯誤的信息。
3.編寫error()和success()函數(shù)分別用于驗證錯誤信息、成功信息
// 成功 function success(obj, msg) { obj.className = 'success'; obj.innerHTML = msg; } // 失敗 function error(obj, msg) { obj.className = 'error'; obj.innerHTML = msg + ',請重新輸入'; }
在上面代碼中,obj參數(shù)表示顯示提示信息的元素對象,msg參數(shù)表示自定義的錯誤信息。
4.獲取驗證規(guī)則和提示信息getRegMsg()函數(shù)
項目分析
① 用戶名:長度4~12,英文大小寫字母。
正則:/^[a-zA-Z]{4,12}$/。
② 密碼:長度6~20,大小寫字母、數(shù)字或下劃線。
正則:/^.{6,20}$/。
③ 確認密碼:要求與密碼框一樣,且兩次輸入相同。
正則:RegExp(‘^’ + 密碼框的值 + '$')
④ 性別:
正則:/^[0-1]*$/。
⑤ 手機號碼:13、14、15、17、18開頭的11位手機號。
正則:/^1[34578]\d{9}$/。
⑥郵箱:用戶名@域名(域名后綴至少2個字符)。
正則:/^(\w+(_|-|.)*)+@(\w+(-)?)+(.\w{2,})+$/。
代碼如下所示:
function getRegMsg(name, display) { var reg = msg = ''; switch (name) { case 'user': reg = /^[a-zA-Z]{4,12}$/; msg = {'success': '用戶名輸入正確', 'error': display}; break; case 'passWord': reg = /^.{6,20}$/; msg = {'success': '密碼輸入正確', 'error': display}; break; case 'repassWord': var con = document.getElementsByTagName('input')[1].value; reg = RegExp("^" + con + "$"); msg = {'success': '兩次密碼輸入正確', 'error': '兩次輸入的密碼不一致'}; break; case 'sex': reg = /^[0-1]*$/; msg = {'success': '性別已選擇', 'error': '性別不能為空'}; break; case 'telephone': reg=/^1[34578]\d{9}$/; msg = {'success': '手機號碼輸入正確', 'error': display}; break; case 'email': reg = /^(\w+(\_|\-|\.)*)+@(\w+(\-)?)+(\.\w{2,})+$/; msg = {'success': '郵箱輸入正確', 'error': display}; break; } return {'reg': reg, 'msg': msg}; }
在上面代碼中, "/^[a-zA-Z]{4,12}$/"表示匹配只包含大小寫的英文字母;
"/^.{6,20}$/"表示匹配由大小寫英文字母、數(shù)字或下劃線長度在6-20范圍內(nèi);
"RegExp("^" + con + "$")"表示獲取用戶輸入的密碼,把它作為檢驗確認密碼是否正確的正則匹配模式;
" /^[0-1]*$/"表示數(shù)字1為男,數(shù)字0為女;
"/^1[34578]\d{9}$/"表示11位數(shù)的手機號碼,以1開頭,第二個數(shù)字可以是(3、4、5、7、8)其中的一個數(shù)字,剩下數(shù)字可以0-9之間任意數(shù)字;
"/^(\w+(_|-|.)*)+@(\w+(-)?)+(.\w{2,})+$/"表示匹配郵箱地址,它有三部分,分別是用戶名、”@“、郵箱域名。
效果圖如下所示:
本文案例參考《JavaScript前端開發(fā)案例教程》,黑馬程序員編著
1.本文基于JavaScript基礎(chǔ),實現(xiàn)表單驗證的功能。對每一個div層、table、tr、td標簽元素進行詳解,讓讀者更好的理解。
2.在JavaScript中首先是表單項添加失去焦點處理,事件處理函數(shù)為inputBlur()。該函數(shù)用于獲取表單name、value及提示信息后,去除空白后,若內(nèi)容為空調(diào)用error()給出提示,否則進行驗證。
“如何使用JavaScript實現(xiàn)表單驗證”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!
網(wǎng)頁名稱:如何使用JavaScript實現(xiàn)表單驗證
網(wǎng)頁鏈接:http://m.rwnh.cn/article38/igjepp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計、移動網(wǎng)站建設(shè)、自適應(yīng)網(wǎng)站、軟件開發(fā)、ChatGPT、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)