您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“JS如何通過正則表達式實現驗證功能”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“JS如何通過正則表達式實現驗證功能”這篇文章吧。
1、驗證電話號碼或者手機號碼
/** * 驗證電話號碼(手機號碼+電話號碼) * @param obj * @returns {Boolean} */ function checkPhoneNum(obj){ if(/^((\d{3}-\d{8}|\d{4}-\d{7,8})|(1[3|5|7|8][0-9]{9}))$/.test(obj)){ return true; } }
2、驗證地址(中文、英文、數字)
/** * 驗證企業地址(中文、英文、數字) * @param obj */ function checkAddress(obj){ if(/^[\u4e00-\u9fa5a-zA-Z0-9]+$/.test(obj)){ return true; } }
3、驗證用戶名
/** * 驗證用戶名輸入格式 * @param obj * @returns {Boolean} */ function checkUserName(obj){ if(/^[a-zA-Z0-9_-]{3,16}$/.test(obj)){ return true; } }
4、驗證密碼
/** * 驗證密碼輸入格式 * @param obj * @returns {Boolean} */ function verifyPassword(obj){ if(/^[a-z0-9_-]{5,18}$/.test(obj)){ return true; } }
5、驗證企業稅號
/** * 驗證稅號 * 15或者17或者18或者20位字母、數字組成 * @param obj * @returns {Boolean} */ function checkTax(obj){ if(/^[A-Z0-9]{15}$|^[A-Z0-9]{17}$|^[A-Z0-9]{18}$|^[A-Z0-9]{20}$/.test(obj)){ return true; } }
6、驗證金額
/** * 驗證金額(可驗證 大于等于零,小于等于99999999.99 的數字) * @param obj * @returns {Boolean} */ function checkMoney(obj){ if(/^([1-9][\d]{0,7}|0)(\.[\d]{1,2})?$/.test(obj)){ return true; } }
7、驗證身份證號,包括大陸身份證號,和港澳臺身份證號,當然這里都只是簡單的規范一下,實際的像香港的身份證號最后的括號里面的校驗位都是需要根據前面的
數字依據一定的加權算法算出來進行校驗的,這里沒有涉及到。如果需要特別精確則可以去研究一番。
/** * 驗證大陸的身份證號 * 驗證身份證號 * 身份證號碼為15位或18位的全數字,或者18位時前17位是數字,最后一位是校驗位,可能是數字或字符X或x * @param obj */ function checkIdCard(obj){ if(/(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/.test(obj)){ return true; } } /** * 驗證港澳臺身份證 * @param obj */ function checkGATIdCard(obj){ var reg1 = /^[A-Z]{1,2}[0-9]{6}[\(|\(]?[0-9A-Z][\)|\)]?$/;//香港格式1 (香港身份證號碼結構:XYabcdef(z)) var reg2 = /^[A-Z][0-9]{8,12}$/;//香港格式2 (H60152555) var reg3 = /^[1|5|7][0-9]{6}[\(|\(]?[0-9A-Z][\)|\)]?$/;//澳門,8位數,不包含出生年月 格式為 xxxxxxx(x) 注:x全為數字,無英文字母 首位數只有1、5、7字開頭的 var reg4 = /^[a-zA-Z][0-9]{9}$/;//臺灣:10位字母和數字 if(reg1.test(obj) || reg2.test(obj) || reg3.test(obj) || reg4.test(obj)){ return true; } }
下面是比較權威的驗證身份證號的寫法:
/** * 身份證15位編碼規則:dddddd yymmdd xx p * dddddd:地區碼 * yymmdd: 出生年月日 * xx: 順序類編碼,無法確定 * p: 性別,奇數為男,偶數為女 * 身份證18位編碼規則:dddddd yyyymmdd xxx y * dddddd:地區碼 * yyyymmdd: 出生年月日 * xxx:順序類編碼,無法確定,奇數為男,偶數為女 * y: 校驗碼,該位數值可通過前17位計算獲得 * 18位號碼加權因子為(從右到左) Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2,1 ] * 驗證位 Y = [ 1, 0, X, 9, 8, 7, 6, 5, 4, 3, 2 ] * 校驗位計算公式:Y_P = mod( ∑(Ai×Wi),11 ) * i為身份證號碼從右往左數的 2...18 位; Y_P為腳丫校驗碼所在校驗碼數組位置 * */ // 構造函數,變量為15位或者18位的身份證號碼 function IdCardValidate(CardNo) { this.Valid = false; this.ID15 = ''; this.ID18 = ''; this.Local = ''; if (CardNo != null) this.SetCardNo(CardNo); } // 設置身份證號碼,15位或者18位 IdCardValidate.prototype.SetCardNo = function(CardNo) { this.ID15 = ''; this.ID18 = ''; this.Local = ''; CardNo = CardNo.replace(" ", ""); var strCardNo; if (CardNo.length == 18) { pattern = /^\d{17}(\d|x|X)$/; if (pattern.exec(CardNo) == null) return; strCardNo = CardNo.toUpperCase(); } else { pattern = /^\d{15}$/; if (pattern.exec(CardNo) == null) return; strCardNo = CardNo.substr(0, 6) + '19' + CardNo.substr(6, 9) strCardNo += this.GetVCode(strCardNo); } this.Valid = this.CheckValid(strCardNo); } // 校驗身份證有效性 IdCardValidate.prototype.IsValid = function() { return this.Valid; } // 返回生日字符串,格式如下,1981-10-10 IdCardValidate.prototype.GetBirthDate = function() { var BirthDate = ''; if (this.Valid) BirthDate = this.GetBirthYear() + '-' + this.GetBirthMonth() + '-' + this.GetBirthDay(); return BirthDate; } // 返回生日中的年,格式如下,1981 IdCardValidate.prototype.GetBirthYear = function() { var BirthYear = ''; if (this.Valid) BirthYear = this.ID18.substr(6, 4); return BirthYear; } // 返回生日中的月,格式如下,10 IdCardValidate.prototype.GetBirthMonth = function() { var BirthMonth = ''; if (this.Valid) BirthMonth = this.ID18.substr(10, 2); if (BirthMonth.charAt(0) == '0') BirthMonth = BirthMonth.charAt(1); return BirthMonth; } // 返回生日中的日,格式如下,10 IdCardValidate.prototype.GetBirthDay = function() { var BirthDay = ''; if (this.Valid) BirthDay = this.ID18.substr(12, 2); return BirthDay; } // 返回性別,1:男,0:女 IdCardValidate.prototype.GetSex = function() { var Sex = ''; if (this.Valid) Sex = this.ID18.charAt(16) % 2; return Sex; } // 返回15位身份證號碼 IdCardValidate.prototype.Get15 = function() { var ID15 = ''; if (this.Valid) ID15 = this.ID15; return ID15; } // 返回18位身份證號碼 IdCardValidate.prototype.Get18 = function() { var ID18 = ''; if (this.Valid) ID18 = this.ID18; return ID18; } // 返回所在省,例如:上海市、浙江省 IdCardValidate.prototype.GetLocal = function() { var Local = ''; if (this.Valid) Local = this.Local; return Local; } //獲取身份證號碼為18位時最后的驗證位 IdCardValidate.prototype.GetVCode = function(CardNo17) { var Wi = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1); var Ai = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); var cardNoSum = 0; for (var i = 0; i < CardNo17.length; i++) cardNoSum += CardNo17.charAt(i) * Wi[i]; var seq = cardNoSum % 11; return Ai[seq]; } IdCardValidate.prototype.CheckValid = function(CardNo18) { if (this.GetVCode(CardNo18.substr(0, 17)) != CardNo18.charAt(17)) return false; if (!this.IsDate(CardNo18.substr(6, 8))) return false; var aCity = { 11 : "北京", 12 : "天津", 13 : "河北", 14 : "山西", 15 : "內蒙古", 21 : "遼寧", 22 : "吉林", 23 : "黑龍江 ", 31 : "上海", 32 : "江蘇", 33 : "浙江", 34 : "安徽", 35 : "福建", 36 : "江西", 37 : "山東", 41 : "河南", 42 : "湖北 ", 43 : "湖南", 44 : "廣東", 45 : "廣西", 46 : "海南", 50 : "重慶", 51 : "四川", 52 : "貴州", 53 : "云南", 54 : "西藏 ", 61 : "陜西", 62 : "甘肅", 63 : "青海", 64 : "寧夏", 65 : "新疆", 71 : "臺灣", 81 : "香港", 82 : "澳門", 91 : "國外" }; if (aCity[parseInt(CardNo18.substr(0, 2))] == null) return false; this.ID18 = CardNo18; this.ID15 = CardNo18.substr(0, 6) + CardNo18.substr(8, 9); this.Local = aCity[parseInt(CardNo18.substr(0, 2))]; return true; } //驗證18位數身份證號碼中的生日是否是有效生日 IdCardValidate.prototype.IsDate = function(strDate) { var r = strDate.match(/^(\d{1,4})(\d{1,2})(\d{1,2})$/); if (r == null) return false; var d = new Date(r[1], r[2] - 1, r[3]); return (d.getFullYear() == r[1] && (d.getMonth() + 1) == r[2] && d .getDate() == r[3]); }
把上面的代碼放到一個js文件中,然后在(jsp)頁面中引入該js文件,再調用即可
var checkIdCard = new IdCardValidate(id_card); if(!checkIdCard.IsValid()){ alert('您輸入的身份證格式不正確!'); return; }
以上是“JS如何通過正則表達式實現驗證功能”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。