1. 概念
正則表達(dá)式描述了一種字符串匹配的模式蝶念,可以用來檢查一個(gè)字符串是否含有某種子串友绝、將匹配的子串做替換或者從某個(gè)字符串中取出符合某個(gè)條件的子串的等堤尾。
2.創(chuàng)建正則表達(dá)式
方式一:字面量創(chuàng)建方式
? ? ? ? ? ? ?var reg = /pattern/flags
方式二:構(gòu)造函數(shù)實(shí)例創(chuàng)建方式
? ? ? ? ? ? ?var reg = new RegExp(pattern, flags)
????????說明:
????????????pattern 正則表達(dá)式
????????????flags 標(biāo)識(shí)(修飾符)
????????????修飾符主要有:
? ? ? ? ? ? ? ? ? ?i 忽略大小寫匹配
? ? ? ? ? ? ? ? ? ?m 多行匹配(即在到達(dá)一行文本末尾時(shí)還會(huì)繼續(xù)尋找下一行中是否與正則匹配的項(xiàng))
? ? ? ? ? ? ? ? ? ? g 全局匹配(模式應(yīng)用于所有的字符串),而非在找到第一個(gè)匹配項(xiàng)時(shí)停止
????????????注意:
????????????字面量創(chuàng)建方式特殊含義的字符不需要轉(zhuǎn)義迁客,實(shí)例創(chuàng)建方式需要轉(zhuǎn)義
????????????示例:
????????????var reg1 = new RegExp('\d'); // 表示的 d (如果需要\,必須轉(zhuǎn)義\\)
????????????var reg2 = new RegExp('\\d'); // 表示的 \d
????????????var reg3 = /\d/; // 表示的 \d
3. 元字符
元字符主要分為代表特殊含義的字符與代表次數(shù)的量詞元字符
特殊含義的元字符
????????????\d : 0-9之間的任意一個(gè)數(shù)字? \d只占一個(gè)位置
????????????\w : 數(shù)字郭宝,字母 ,下劃線 0-9 a-z A-Z _
????????????\s : 空格或者空白等
????????????\D : 除了\d
????????????\W : 除了\w
????????????\S : 除了\s
????????????. : 除了\n之外的任意一個(gè)字符
????????????\ : 轉(zhuǎn)義字符
????????????| : 或者
????????????() : 分組
????????????\n : 匹配換行符
????????????\b : 匹配邊界 字符串的開頭和結(jié)尾 空格的兩邊都是邊界 => 不占用字符串位數(shù)
????????????^ : 限定開始位置 => 本身不占位置
????????????$ : 限定結(jié)束位置 => 本身不占位置
????????????[a-z] : 任意字母 []中的表示任意一個(gè)都可以
????????????[^a-z] : 非字母 []中^代表除了
????????????[abc] : abc三個(gè)字母中的任何一個(gè) [^abc]除了這三個(gè)字母中的任何一個(gè)字符
次數(shù)的量詞元字符
????????????* : 0到多個(gè)
????????????+ : 1到多個(gè)
????????????? : 0次或1次 可有可無
????????????{n} : 正好n次掷漱;
????????????{n,} : n到多次
????????????{n,m} : n次到m次
4. Nodejs中和正則相關(guān)的一些方法
- reg.test(str)? //用來驗(yàn)證字符串是否符合正則 符合返回true 否則返回false
示例:
????var str = 'hello';
????var reg = /\w+/; // 模式:匹配1到多個(gè)的數(shù)字粘室、字母、下劃線
????console.log(reg.test(str)); // true
- reg.exec() //用來捕獲符合規(guī)則的字符串
示例:
????var str = 'tom287aaa879bbb666';
????var reg = /\d+/;
????console.log(reg.exec(str));
????// 返回?cái)?shù)組中 [0:"287", index:3, input:"tom287aaa879bbb666"]
????// 0 : "123" 表示我們捕獲到的字符串
????// index: 3 表示捕獲開始位置的索引
????// input: tom287aaa879bbb666 表示原有的字符串
標(biāo)識(shí)符 g 作用
????var str = 'abc123cba456aaa789';
????var reg = /\d+/g;? //此時(shí)加了標(biāo)識(shí)符g
????console.log(reg.lastIndex) // lastIndex : 0
????console.log(reg.exec(str)) //? ["123", index: 3, input: "abc123cba456aaa789"]
????console.log(reg.lastIndex) // lastIndex : 6
????console.log(reg.exec(str)) // ["456", index: 9, input: "abc123cba456aaa789"]
????console.log(reg.lastIndex) // lastIndex : 12
????console.log(reg.exec(str)) // ["789", index: 15, input: "abc123cba456aaa789"]
????console.log(reg.lastIndex) // lastIndex : 18
????console.log(reg.exec(str)) // null
????console.log(reg.lastIndex) // lastIndex : 0
注意:
????每次調(diào)用exec方法時(shí),捕獲到的字符串都不相同
????lastIndex :這個(gè)屬性記錄的就是下一次捕獲從哪個(gè)索引開始卜范。
????當(dāng)未開始捕獲時(shí)衔统,這個(gè)值為0。
????如果當(dāng)前次捕獲結(jié)果為null海雪。那么lastIndex的值會(huì)被修改為0.下次從頭開始捕獲锦爵。
????而且這個(gè)lastIndex屬性還支持人為賦值。
- str.match(reg) 如果匹配成功奥裸,就返回匹配成功的數(shù)組险掀,如果匹配不成功,就返回null
????如果正則表達(dá)式?jīng)]有標(biāo)識(shí)符 g 則exec與match功能一樣的
????如果正則表達(dá)式有標(biāo)識(shí)符 g 則exec與match有明顯區(qū)別
????當(dāng)全局匹配時(shí)湾宙,match方法會(huì)一次性把符合匹配條件的字符串全部捕獲到數(shù)組中,
????如果想用exec來達(dá)到同樣的效果需要執(zhí)行多次exec方法樟氢。
示例:
????var str = 'abc123cba456aaa789';
????var reg = /\d+/g;
????console.log(reg.exec(str)); // ["123", index: 3, input: "abc123cba456aaa789"]
????console.log(str.match(reg)); // ["123", "456", "789"]
- str.replace() 正則去匹配字符串,匹配成功的字符去替換成新的字符串
語法:str.replace(reg,newStr);
示例:
????var str = 'b123bc456d';
????var res = str.replace(/\d/g,'Q')
????console.log(res) // "bQQQbcQQQd" 將所有的數(shù)字替換字符Q
5. 正則的特性 - 貪婪性 與 懶惰性
貪婪性
所謂的貪婪性就是正則在捕獲時(shí)侠鳄,每一次會(huì)盡可能多的去捕獲符合條件的內(nèi)容埠啃。
如果我們想盡可能的少的去捕獲符合條件的字符串的話,可以在量詞元字符后加?
懶惰性
懶惰性則是正則在成功捕獲一次后不管后邊的字符串有沒有符合條件的都不再捕獲伟恶。
如果想捕獲目標(biāo)中所有符合條件的字符串的話碴开,我們可以用標(biāo)識(shí)符g來標(biāo)明是全局捕獲
示例:
????var str = '123aaa456';
????var reg = /\d+/;? //只捕獲一次,一次盡可能多的捕獲
????var res = str.match(reg)
????console.log(res)? // ["123", index: 0, input: "123aaa456"]
????reg = /\d+?/g; //解決貪婪性、懶惰性
????res = str.match(reg)
????console.log(res)? // ["1", "2", "3", "4", "5", "6"]
6. 正則運(yùn)算符的優(yōu)先級(jí)
正則表達(dá)式從左到右進(jìn)行計(jì)算知押,并遵循優(yōu)先級(jí)順序叹螟,這與算術(shù)表達(dá)式非常類似鹃骂。
相同優(yōu)先級(jí)的會(huì)從左到右進(jìn)行運(yùn)算台盯,不同優(yōu)先級(jí)的運(yùn)算先高后低。
下面是常見的運(yùn)算符的優(yōu)先級(jí)排列
依次從最高到最低說明各種正則表達(dá)式運(yùn)算符的優(yōu)先級(jí)順序:
\ : 轉(zhuǎn)義符
(), (?:), (?=), []? => 圓括號(hào)和方括號(hào)
*, +, ?, {n}, {n,}, {n,m}? => 量詞限定符
^, $, \任何元字符畏线、任何字符
|? ? ? => 替換静盅,"或"操作
字符具有高于替換運(yùn)算符的優(yōu)先級(jí),一般用 | 的時(shí)候,為了提高 | 的優(yōu)先級(jí)蒿叠,我們常用()來提高優(yōu)先級(jí)
如: 匹配 food或者foot的時(shí)候 reg = /foo(t|d)/ 這樣來匹配