JS實現表單驗證案例
本文實例為大傢分享瞭JS實現表單驗證案例的具體代碼,供大傢參考,具體內容如下
1.當輸入框失去焦點時,驗證輸入內容是否符合要求
(1)獲取表單輸入框
(2)綁定 onblur 事件
(3)獲取輸入內容
(4)判斷是否符合規則
(5)如果不符合規則,則顯示錯誤提示信息
2.當點擊註冊按鈕是,判斷所有輸入框的內容是否符合要求,如果不符合則阻止表單提交
(1)獲取表單對象
(2)微表單對象綁定 onsubmit
(3)判斷所有輸入框是否都符合要求,如果符合,則返回true,如果有一項不符合,則返回false
<body> <div class="form-div"> <div class="reg-content"> <h1>歡迎註冊</h1> <span>已有帳號?</span> <a href="#" rel="external nofollow" >登錄</a> </div> <form id="reg-form" action="#" method="get"> <table> <tr> <td>用戶名</td> <td class="inputs"> <input name="username" type="text" id="username"> <br> <span id="username_err" class="err_msg" style="display: none">用戶名不太受歡迎</span> </td> </tr> <tr> <td>密碼</td> <td class="inputs"> <input name="password" type="password" id="password"> <br> <span id="password_err" class="err_msg" style="display: none">密碼格式有誤</span> </td> </tr> <tr> <td>手機號</td> <td class="inputs"><input name="tel" type="text" id="tel"> <br> <span id="tel_err" class="err_msg" style="display: none">手機號格式有誤</span> </td> </tr> </table> <div class="buttons"> <input value="註 冊" type="submit" id="reg_btn"> </div> <br class="clear"> </form> </div> <script> //1. 驗證用戶名是否符合規則 //1.1 獲取用戶名的輸入框 var usernameInput = document.getElementById("username"); //1.2 綁定onblur事件 失去焦點 usernameInput.onblur = checkUsername; function checkUsername() { //1.3 獲取用戶輸入的用戶名 var username = usernameInput.value.trim(); //1.4 判斷用戶名是否符合規則:長度 6~12,單詞字符組成 var reg = /^\w{6,12}$/; var flag = reg.test(username); //var flag = username.length >= 6 && username.length <= 12; if (flag) { //符合規則 document.getElementById("username_err").style.display = 'none'; } else { //不合符規則 document.getElementById("username_err").style.display = ''; } return flag; } //1. 驗證密碼是否符合規則 //1.1 獲取密碼的輸入框 var passwordInput = document.getElementById("password"); //1.2 綁定onblur事件 失去焦點 passwordInput.onblur = checkPassword; function checkPassword() { //1.3 獲取用戶輸入的密碼 var password = passwordInput.value.trim(); //1.4 判斷密碼是否符合規則:長度 6~12 var reg = /^\w{6,12}$/; var flag = reg.test(password); //var flag = password.length >= 6 && password.length <= 12; if (flag) { //符合規則 document.getElementById("password_err").style.display = 'none'; } else { //不合符規則 document.getElementById("password_err").style.display = ''; } return flag; } //1. 驗證手機號是否符合規則 //1.1 獲取手機號的輸入框 var telInput = document.getElementById("tel"); //1.2 綁定onblur事件 失去焦點 telInput.onblur = checkTel; function checkTel() { //1.3 獲取用戶輸入的手機號 var tel = telInput.value.trim(); //1.4 判斷手機號是否符合規則:長度 11,數字組成,第一位是1 //var flag = tel.length == 11; var reg = /^[1]\d{10}$/; var flag = reg.test(tel); if (flag) { //符合規則 document.getElementById("tel_err").style.display = 'none'; } else { //不合符規則 document.getElementById("tel_err").style.display = ''; } return flag; } //1. 獲取表單對象 var regForm = document.getElementById("reg-form"); //2. 綁定onsubmit 事件 regForm.onsubmit = function () { //挨個判斷每一個表單項是否都符合要求,如果有一個不合符,則返回false var flag = checkUsername() && checkPassword() && checkTel(); return flag; } </script> </body>
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。