JS正則表達(dá)式實(shí)用總結(jié)

一、什么是正則表達(dá)式

正則表達(dá)式是由一個(gè)字符序列形成的搜索模式,搜索模式可用于文本搜索和文本替換。

二、創(chuàng)建正則表達(dá)式

JS正則表達(dá)式的創(chuàng)建有兩種方式: new RegExp() 和 直接字面量。

var re=new RegExp ();
//RegExp 是JS中的類,同Array類似。然而這個(gè)創(chuàng)建方法沒有指定表達(dá)式內(nèi)容
re=new RegExp ("a");
//最簡單的正則表達(dá)式,將匹配字母a 
re=new RegExp ("a","i");
//重載的構(gòu)造函數(shù),其第二個(gè)參數(shù)指定將不區(qū)分大小寫

其中,對于第二個(gè)參數(shù),為可選參數(shù),包括三種:

  • g:全文查找;
  • i:不區(qū)分大小寫;
  • m:多行查找;

然而更為常見的正則表達(dá)式創(chuàng)建法則是:字面量的聲明方式。 即:

var re=/a/i;
//其作用同:re=new RegExp ("a","i"),而且更常用。

三、正則表達(dá)式本身的方法

在 JavaScript 中,RegExp 對象是一個(gè)預(yù)定義了屬性和方法的正則表達(dá)式對象。

  • test() 方法
    test() 方法用于檢測一個(gè)字符串是否匹配某個(gè)模式,如果字符串中含有匹配的文本,則返回true,否則返回 false
//以下實(shí)例用于搜索字符串中的字符 "e":
var patt = /e/;patt.test("The best things in life are free!");
字符串中含有 "e",所以該實(shí)例輸出為:
true
以上兩行代碼可以合并為一行:
/e/.test("The best things in life are free!")
  • exec() 方法
    exec() 方法用于檢索字符串中的正則表達(dá)式的匹配。
    該函數(shù)返回一個(gè)數(shù)組,其中存放匹配的結(jié)果。如果未找到匹配,則返回值為 null
    以下實(shí)例用于搜索字符串中的字母 e:
/e/.exec("The best things in life are free!");
字符串中含有 "e",所以該實(shí)例輸出為:
e

比較常用的就是正則表達(dá)式的test方法了,因?yàn)榇蠖嘀恍枰溃耗硞€(gè)字符串是否匹配某正則表達(dá)式,是則True,否則為False

四、字符串對象中與正則表達(dá)式有關(guān)的方法

在 JavaScript 中,正則表達(dá)式通常用于兩個(gè)字符串方法 : search()replace()

  • search() 方法
    1. 檢索與正則表達(dá)式相匹配的子字符串,并返回子串的起始位置。
//使用正則表達(dá)式搜索 "Runoob" 字符串,且不區(qū)分大小寫:
var str = "Visit Runoob!"; 
var n = str.search(/Runoob/i);
//輸出結(jié)果為:
6
  1. 用于檢索字符串中指定的子字符串。
    search方法可使用字符串作為參數(shù)。字符串參數(shù)會(huì)轉(zhuǎn)換為正則表達(dá)式:
//檢索字符串中 "Runoob" 的子串:
var str = "Visit Runoob!"; 
var n = str.search("Runoob");
  • replace() 方法
    replace() 方法將接收字符串作為參數(shù):
var str="Visit W3CSchool!";
var n=str.replace("W3CSchool","Runoob");
console.log(n);
//結(jié)果Visit Runoob!
console.log(str);
//結(jié)果Visit W3CSchool!

五、常用語法分析

5.1 ()、[]、{} 的區(qū)別

先看個(gè)例子
校驗(yàn)字符串是否全由8位數(shù)字組成

function isStudentNo(str) {
    var reg=/^[0-9]{8}$/;   /*定義驗(yàn)證表達(dá)式*/
    return reg.test(str);     /*進(jìn)行驗(yàn)證*/
}

[]是定義匹配的字符范圍。[0-9]表示查找任何從 0 至 9 的數(shù)字。

{} 一般用來表示匹配的長度。{8}表示位數(shù)為8位。

() 的作用是提取匹配的字符串。表達(dá)式中有幾個(gè)()就會(huì)得到幾個(gè)相應(yīng)的匹配字符串。比如(\s+)表示連續(xù)空格的字符串。

5.2 ^ 和 $

^ 匹配一個(gè)字符串的開頭,比如 (^a) 就是匹配以字母a開頭的字符串

$ 匹配一個(gè)字符串的結(jié)尾,比如 (b$) 就是匹配以字母b結(jié)尾的字符串

^還有另個(gè)一個(gè)作用就是取反,比如[^xyz]表示匹配的字符串不包含xyz

需要注意的是:如果^出現(xiàn)在[]中一般表示取反,而出現(xiàn)在其他地方則是匹配字符串的開頭。

5.3 \d \s \w .

\d 匹配一個(gè)非負(fù)整數(shù), 等價(jià)于 [0-9]

\s 匹配一個(gè)空白字符;

\w 匹配一個(gè)英文字母或數(shù)字,等價(jià)于[0-9a-zA-Z]

. 匹配除換行符以外的任意字符,等價(jià)于[^\n]

5.4 * + ?

*表示匹配前面元素0次或多次,比如(\s*)就是匹配0個(gè)或多個(gè)空格;

+ 表示匹配前面元素1次或多次,比如(\d+)就是匹配由至少1個(gè)整數(shù)組成的字符串;

?表示匹配前面元素0次或1次,相當(dāng)于{0,1},比如(\w?) 就是匹配最多由1個(gè)字母或數(shù)字組成的字符串 。

六、語法大全

修飾符
修飾符用于執(zhí)行區(qū)分大小寫和全局匹配:

修飾符 描述
i 執(zhí)行對大小寫不敏感的匹配。
g 執(zhí)行全局匹配(查找所有匹配而非在找到第一個(gè)匹配后停止)。
m 執(zhí)行多行匹配。

方括號(hào)
方括號(hào)用于查找某個(gè)范圍內(nèi)的字符:

表達(dá)式 描述
[abc] 查找方括號(hào)之間的任何字符。
[^abc] 查找任何不在方括號(hào)之間的字符。
[0-9] 查找任何從 0 至 9 的數(shù)字。
[a-z] 查找任何從小寫 a 到小寫 z 的字符。
[A-Z] 查找任何從大寫 A 到大寫 Z 的字符。
[A-z] 查找任何從大寫 A 到小寫 z 的字符。
[adgk] 查找給定集合內(nèi)的任何字符。
`[^adgk ]` 查找給定集合外的任何字符。

元字符
元字符(Metacharacter)是擁有特殊含義的字符:

元字符 描述
. 查找單個(gè)字符,除了換行和行結(jié)束符。
\w 查找單詞字符。
\W 查找非單詞字符。
\d 查找數(shù)字。
\D 查找非數(shù)字字符。
\s 查找空白字符。
\S 查找非空白字符。
\b 匹配單詞邊界。
\B 匹配非單詞邊界。
\0 查找 NULL 字符。
\n 查找換行符。
\f 查找換頁符。
\r 查找回車符。
\t 查找制表符。
\v 查找垂直制表符。
\xxx 查找以八進(jìn)制數(shù) xxx 規(guī)定的字符。
\xdd 查找以十六進(jìn)制數(shù) dd 規(guī)定的字符。
\uxxxx 查找以十六進(jìn)制數(shù) xxxx 規(guī)定的 Unicode 字符。

量詞

量詞 描述
n+ 匹配任何包含至少一個(gè) n的字符串。例如,/a+/ 匹配 candy中的 acaaaaaaandy 中所有的a
n* 匹配任何包含零個(gè)或多個(gè) n 的字符串。例如,/bo*/匹配 A ghost booooed 中的 booooA bird warbled 中的 b,但是不匹配 A goat grunted
n? 匹配任何包含零個(gè)或一個(gè) n 的字符串。例如,/e?le?/ 匹配 angel 中的 elangle 中的 le
n{X} 匹配包含X 個(gè)n的序列的字符串。例如,/a{2}/不匹配 candy, 中的 a,但是匹配 caandy, 中的兩個(gè) a,且匹配 caaandy. 中的前兩個(gè) a
n{X,} X 是一個(gè)正整數(shù)。前面的模式 n 連續(xù)出現(xiàn)至少X 次時(shí)匹配。例如,/a{2,}/不匹配 candy 中的 a,但是匹配 caandycaaaaaaandy. 中所有的 a
n{X,Y} XY 為正整數(shù)。前面的模式n 連續(xù)出現(xiàn)至少 X次,至多 Y次時(shí)匹配。例如,/a{1,3}/ 不匹配 cndy,匹配 candy, 中的 acaandy, 中的兩個(gè) a,匹配 caaaaaaandy 中的前面三個(gè) a。注意,當(dāng)匹配 caaaaaaandy 時(shí),即使原始字符串擁有更多的 a,匹配項(xiàng)也是 aaa
n{X,} 匹配包含至少 X 個(gè)n 的序列的字符串。
n$ 匹配任何結(jié)尾為 n的字符串。
^n 匹配任何開頭為n的字符串。
?=n 匹配任何其后緊接指定字符串n 的字符串。
?!n 匹配任何其后沒有緊接指定字符串 n 的字符串。

七、12個(gè)常用的js正則表達(dá)式

  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;">元
//第二種對于表單動(dòng)態(tài)增加的方式,只能在js方法中驗(yàn)證。
 var amount=$("#amount").val();
 if (amount.search(/^\d*(?:\.\d{0,2})?$/)==-1) {
   alert("金額格式不對,最多有兩位小數(shù)");
   return false;
}
  1. 驗(yàn)證郵箱格式
var reg=/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/;
 var email=$("#email").val();
 if(!reg.test(email) ){
    alert("請輸入符合規(guī)范的郵箱賬號(hào)!");
    return false;
   }
  1. 密碼采用數(shù)字、字母、特殊字符且長度為8-20位
function validatePwd(str) {
if (/^.*?[\d]+.*$/.test(str) && /^.*?[A-Za-z]/.test(str)
&& /^.*?[~/`!@#$%^&*()_+|{}?;:><\-\]\\[\/].*$/.test(str) && /^.{8,20}$/.test(str)) {
return true;
}
return false;
}
  1. 驗(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);
}
  1. 判斷是否是漢字
/**
 * 判斷是否是漢字
 *
 * @param charValue
 *   要驗(yàn)證的數(shù)據(jù)
 * @returns 匹配返回true 不匹配返回false
 */
function isCharacter(charValue) {
 var reg = /^[\u4e00-\u9fa5]{0,}$/;
 return reg.test(charValue);
}
  1. 是否為字母:true:是,false:不是
function isChar(charValue){
 var charPattern=/^[a-zA-Z]*$/; //是否為字母
 result=charPattern.test(charValue);
 return result;
}
  1. 判斷是否為數(shù)字
function isNum(numValue){
 var numPattern=/^\d*$/; //數(shù)字的正則表達(dá)式
 result=numPattern.test(numValue);
 return result;
}
  1. 整數(shù)的正則表達(dá)式
function isInt(intValue){
  var intPattern=/^0$|^[1-9]\d*$/; //整數(shù)的正則表達(dá)式
 result=intPattern.test(intValue);
  return result;
 }
  1. 是否為字母和數(shù)字
function isCharNum(flagValue){
 var flagPattern=/^[a-zA-Z0-9]*$/; //是否為字母和數(shù)字
 result=flagPattern.test(flagValue);
 return result;
}
  1. 檢驗(yàn)18位身份證號(hào)碼
/**
 * 檢驗(yàn)18位身份證號(hào)碼(15位號(hào)碼可以只檢測生日是否正確即可,自行解決)
 *
 * @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++) {
// 對前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;
}
}
  1. 驗(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));
 // 對于老身份證中的你年齡則不需考慮千年蟲問題而使用getYear()方法
 if (temp_date.getYear() != parseFloat(year)
   || temp_date.getMonth() != parseFloat(month) - 1
   || temp_date.getDate() != parseFloat(day)) {
  return false;
 } else {
  return true;
 }
}
  1. 驗(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()獲取年份,避免千年蟲問題
 if (temp_date.getFullYear() != parseFloat(year)
   || temp_date.getMonth() != parseFloat(month) - 1
   || temp_date.getDate() != parseFloat(day)) {
  return false;
 } else {
  return true;
 }
}

參考資料:
JS中正則表達(dá)式概述
JS正則表達(dá)式常用總結(jié)
12個(gè)常用的js正則表達(dá)式
JavaScript RegExp 對象

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,837評(píng)論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,196評(píng)論 3 414
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,688評(píng)論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,654評(píng)論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,456評(píng)論 6 406
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 54,955評(píng)論 1 321
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,044評(píng)論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,195評(píng)論 0 287
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,725評(píng)論 1 333
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,608評(píng)論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,802評(píng)論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,318評(píng)論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,048評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,422評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,673評(píng)論 1 281
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,424評(píng)論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,762評(píng)論 2 372

推薦閱讀更多精彩內(nèi)容