js正則表達式:驗證郵箱格式、密碼復雜度、手機號碼、QQ號碼
<script type="text/javascript"> $(function () { $("input[name='sub']").on("click", function () { if (!isEmail($("input[name='email']").val())) { $("span[name='email']").html("郵箱格式錯誤"); return false; } else { $("span[name='email']").html(""); } if (checkStrong($("input[name='password']").val()) < 3) { $("span[name='password']").html("密碼太過簡單"); return false; } else { $("span[name='password']").html(""); } if (!isQQ($.trim($("input[name='qq']").val()))) { $("span[name='qq']").html("請輸入正確的QQ號碼"); return false; } else { $("span[name='qq']").html(""); } if (!isPhone($.trim($("input[name='mnumber']").val()))) { $("span[name='mnumber']").html("請輸入正確的手機號碼"); return false; } else { $("span[name='mnumber']").html(""); } return true; }); }); /*** 檢查字符串是否為合法QQ號碼 * @param {String} 字符串 * @return {bool} 是否為合法QQ號碼 */ function isQQ(aQQ) { var bValidate = RegExp(/^[1-9][0-9]{4,9}$/).test(aQQ); if (bValidate) { return true; } else return false; } /** * 檢查字符串是否為合法手機號碼 * @param {String} 字符串 * @return {bool} 是否為合法手機號碼 */ function isPhone(aPhone) { var bValidate = RegExp(/^(0|86|17951)?(13[0-9]|15[012356789]|18[0-9]|14[57])[0-9]{8}$/).test(aPhone); if (bValidate) { return true; } else return false; } /** * 檢查字符串是否為合法email地址 * @param {String} 字符串 * @return {bool} 是否為合法email地址 */ function isEmail(aEmail) { var bValidate = RegExp(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(aEmail); if (bValidate) { return true; } else return false; } /** * 檢查字符串是否是整數 * @param {String} 字符串 * @return {bool} 是否是整數 */ function isInteger(s) { var isInteger = RegExp(/^[0-9]+$/); return (isInteger.test(s)); } /* 判斷字符類型 */ function CharMode(iN) { if (iN >= 48 && iN <= 57) //數字 return 1; if (iN >= 65 && iN <= 90) //大寫字母 return 2; if (iN >= 97 && iN <= 122) //小寫 return 4; else return 8; //特殊字符 } /* 統計字符類型 */ function bitTotal(num) { modes = 0; for (i = 0; i < 4; i++) { if (num & 1) modes++; num >>>= 1; } return modes; } /* 返回密碼的強度級別 */ function checkStrong(sPW) { if (sPW.length <= 4) return 0; //密碼太短 Modes = 0; for (i = 0; i < sPW.length; i++) { //測試每一個字符的類別并統計一共有多少種模式. Modes |= CharMode(sPW.charCodeAt(i)); } return bitTotal(Modes); } </script></pre>
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!