12個(gè)常用的js正則表達(dá)式
在這篇文章里,我已經(jīng)編寫(xiě)了12個(gè)超有用的正則表達(dá)式,這可是WEB開(kāi)發(fā)人員的最?lèi)?ài)哦。
1.在input框中只能輸入金額,其實(shí)就是只能輸入最多有兩位小數(shù)的數(shù)字
//第一種在input輸入框限制 <input type="text" maxlength="8" class="form-control" id="amount" style="margin-right: 2px;" value="" onChange="count();" onkeyup="if (this.value==this.value2) return; if (this.value.search(/^\d*(?:\.\d{0,2})?$/)==-1) this.value=(this.value2)?this.value2:'';else this.value2=this.value;">元 //第二種對(duì)于表單動(dòng)態(tài)增加的方式,只能在js方法中驗(yàn)證。 var amount=$("#amount").val(); if (amount.search(/^\d*(?:\.\d{0,2})?$/)==-1) { alert("金額格式不對(duì),最多有兩位小數(shù)"); return false; }
2.驗(yàn)證郵箱格式
var reg=/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/; var email=$("#email").val(); if(!reg.test(email) ){ alert("請(qǐng)輸入符合規(guī)范的郵箱賬號(hào)!"); return false; }
3.密碼采用數(shù)字、字母、特殊字符且長(zhǎng)度為8-20位
function validatePwd(str) { if (/^.*?[\d]+.*$/.test(str) && /^.*?[A-Za-z]/.test(str) && /^.*?[~/`!@#$%^&*()_+|{}?;:><\-\]\\[\/].*$/.test(str) && /^.{8,20}$/.test(str)) { return true; } return false; }
4.驗(yàn)證電話號(hào)碼
/** * 驗(yàn)證電話號(hào)碼 * @param phoneValue 要驗(yàn)證的電話號(hào)碼 * @returns 匹配返回true 不匹配返回false */ function validatePhone(phoneValue) { phoneValue = valueTrim(phoneValue); var reg = /^[1][0-9]{10}$/; return reg.test(phoneValue); }
5.判斷是否是漢字
/** * 判斷是否是漢字 * * @param charValue * 要驗(yàn)證的數(shù)據(jù) * @returns 匹配返回true 不匹配返回false */ function isCharacter(charValue) { var reg = /^[\u4e00-\u9fa5]{0,}$/; return reg.test(charValue); }
6.是否為字母:true:是,false:不是
function isChar(charValue){ var charPattern=/^[a-zA-Z]*$/; //是否為字母 result=charPattern.test(charValue); return result; }
7.判斷是否為數(shù)字
function isNum(numValue){ var numPattern=/^\d*$/; //數(shù)字的正則表達(dá)式 result=numPattern.test(numValue); return result; }
8.整數(shù)的正則表達(dá)式
function isInt(intValue){ var intPattern=/^0$|^[1-9]\d*$/; //整數(shù)的正則表達(dá)式 result=intPattern.test(intValue); return result; }
9.是否為字母和數(shù)字
function isCharNum(flagValue){ var flagPattern=/^[a-zA-Z0-9]*$/; //是否為字母和數(shù)字 result=flagPattern.test(flagValue); return result; }
10.檢驗(yàn)18位身份證號(hào)碼
/** * 檢驗(yàn)18位身份證號(hào)碼(15位號(hào)碼可以只檢測(cè)生日是否正確即可,自行解決) * * @param idCardValue * 18位身份證號(hào) * @returns 匹配返回true 不匹配返回false */ function idCardVildate(cid) { var arrExp = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];// 加權(quán)因子 var arrValid = [ 1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2 ];// 校驗(yàn)碼 var reg = /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/; if (reg.test(cid)) { var sum = 0, idx; for (var i = 0; i < cid.length - 1; i++) { // 對(duì)前17位數(shù)字與權(quán)值乘積求和 sum += parseInt(cid.substr(i, 1), 10) * arrExp[i]; } // 計(jì)算模(固定算法) idx = sum % 11; // 檢驗(yàn)第18為是否與校驗(yàn)碼相等 return arrValid[idx] == cid.substr(17, 1).toUpperCase(); } else { return false; } }
11.驗(yàn)證15位數(shù)身份證號(hào)碼中的生日是否是有效生日
function isValidityBrithBy15IdCard(idCard15) { var year = idCard15.substring(6, 8); var month = idCard15.substring(8, 10); var day = idCard15.substring(10, 12); var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day)); // 對(duì)于老身份證中的你年齡則不需考慮千年蟲(chóng)問(wèn)題而使用getYear()方法 if (temp_date.getYear() != parseFloat(year) || temp_date.getMonth() != parseFloat(month) - 1 || temp_date.getDate() != parseFloat(day)) { return false; } else { return true; } }
12.驗(yàn)證18位數(shù)身份證號(hào)碼中的生日是否是有效生日
function isValidityBrithBy18IdCard(idCard18) { var year = idCard18.substring(6, 10); var month = idCard18.substring(10, 12); var day = idCard18.substring(12, 14); var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day)); // 這里用getFullYear()獲取年份,避免千年蟲(chóng)問(wèn)題 if (temp_date.getFullYear() != parseFloat(year) || temp_date.getMonth() != parseFloat(month) - 1 || temp_date.getDate() != parseFloat(day)) { return false; } else { return true; } }
這就是小編整理的web開(kāi)發(fā)中常用的表單驗(yàn)證的正則表達(dá)式,希望大家喜歡。
- 比較正宗的驗(yàn)證郵箱的正則表達(dá)式j(luò)s代碼詳解
- 實(shí)用的JS正則表達(dá)式(手機(jī)號(hào)碼/IP正則/郵編正則/電話等)
- js正則表達(dá)式的使用詳解
- JS正則表達(dá)式大全(整理詳細(xì)且實(shí)用)
- JS正則表達(dá)式驗(yàn)證數(shù)字代碼
- js正則表達(dá)式中test,exec,match方法的區(qū)別說(shuō)明
- js正則表達(dá)式匹配數(shù)字字母下劃線等
- js正則表達(dá)式基本語(yǔ)法(精粹)
- JavaScript正則表達(dá)式驗(yàn)證身份證號(hào)碼是否合法(兩種方法)
- JavaScript正則表達(dá)式解析URL的技巧
- javascript正則表達(dá)式總結(jié)
相關(guān)文章
用Javascript正則實(shí)現(xiàn)url鏈接的解析類(lèi)
一個(gè)非常健全的 Javascript 鏈接(URL)解析類(lèi),他用了正則表達(dá)式可以準(zhǔn)確獲取一個(gè)完整的 URL 中每個(gè)部分的內(nèi)容,包括協(xié)議、URL中包含的用戶名和密碼、主機(jī)名、端口、路徑名、參數(shù)、錨點(diǎn)(Fragment Anchor)等信息2008-06-06ASP 正則表達(dá)式常用的幾種方法(execute、test、replace)
asp下正則表達(dá)式常用的幾種方法,需要的朋友可以參考下。2009-12-12Java正則表達(dá)式基礎(chǔ)入門(mén)知識(shí)
正則表達(dá)式是一種可以用于模式匹配和替換的規(guī)范,一個(gè)正則表達(dá)式就是由普通的字符(例如字符a到z)以及特殊字符(元字符)組成的文字模式,它 用以描述在查找文字主體時(shí)待匹配的一個(gè)或多個(gè)字符串。2015-09-09正則表達(dá)式實(shí)現(xiàn)字符串每4位后自動(dòng)加空格效果(兩種方法)
本文通過(guò)兩種方法給大家介紹了正則表達(dá)式實(shí)現(xiàn)字符串每4位后自動(dòng)加空格效果,需要的朋友可以參考下2018-09-09js中string之正則表達(dá)式replace方法詳解
本篇文章主要介紹了js中string之正則表達(dá)式replace方法詳解,replace方法是javascript涉及到正則表達(dá)式中較為復(fù)雜的一個(gè)方法,嚴(yán)格上說(shuō)應(yīng)該是string對(duì)象的方法。2017-03-03