正則表達(dá)式
- 在JavaScript中拇泛,正則表達(dá)式也是對(duì)象,是一種索引類(lèi)型思灌。
- 使用一個(gè)正則表達(dá)式字面量是最簡(jiǎn)單的方式俺叭,兩個(gè)
/
是正則表達(dá)式的定界符。 - 語(yǔ)法:var reg = /abc/; 正則表達(dá)式字面量在腳本加載后編譯泰偿。如果正則表達(dá)式是常量熄守,則可以獲得更好的性能。
- 使用
RegExp
對(duì)象的構(gòu)造函數(shù):var re = new RegExp("abc")
相關(guān)正則方法
-
字符串的方法:
- split() 根據(jù)匹配字符串切割父字符串,返回一個(gè)
數(shù)組
裕照。 - match() 使用正則表達(dá)式與字符串相比較攒发,返回一個(gè)包含匹配結(jié)果的
數(shù)組
。 - search() 對(duì)正則表達(dá)式或指定字符串進(jìn)行搜索晋南,返回第一個(gè)出現(xiàn)的匹配項(xiàng)的下標(biāo)惠猿。如果匹配不成功,返回 -1负间。
- replace() 用正則表達(dá)式和字符串直接比較偶妖,然后用新的子串來(lái)替換被匹配的子串。
- split() 根據(jù)匹配字符串切割父字符串,返回一個(gè)
-
正則表達(dá)式方法:
- exec() 在目標(biāo)字符串中執(zhí)行一次正則匹配操作唉擂。不論有沒(méi)有全局修飾符餐屎,都只會(huì)在找到第一個(gè)之后停止撒桨。如果匹配不到返回一個(gè)null工育。可以通過(guò)打點(diǎn)調(diào)用返回結(jié)果中的
index
屬性机久,查看返回結(jié)果的開(kāi)始下標(biāo)空扎。 - 語(yǔ)法:
正則表達(dá)式.exec(str)
- exec() 在目標(biāo)字符串中執(zhí)行一次正則匹配操作唉擂。不論有沒(méi)有全局修飾符餐屎,都只會(huì)在找到第一個(gè)之后停止撒桨。如果匹配不到返回一個(gè)null工育。可以通過(guò)打點(diǎn)調(diào)用返回結(jié)果中的
let str = "aaabcccc";
let strArr = /abc/.exec(str);
* test() 檢測(cè)字符串是否匹配正則表達(dá)式藏鹊。返回一個(gè)布爾值。
* 語(yǔ)法:`正則表達(dá)式.test(str)`
let str = "a bc";
let regResult = /\s/.exec(str);
正則表達(dá)式的組成
- 由一些普通字符和一些特殊字符(又叫元字符)組成转锈。普通字符包括大小寫(xiě)的字母和數(shù)字盘寡,而元字符則具有特殊的意義。
- 特殊字符:JavaScript中常用特殊字符有 () [] {} \ ^ $ | ? * + .
- 如果想匹配這類(lèi)字符IXUS用轉(zhuǎn)義符號(hào) \ 撮慨。
- 預(yù)定義特殊字符:
- \t /\t/ 制表符
- \s /\s/ 空格
- \n /\n/ 回車(chē)符
- \f /\f/ 換頁(yè)符
- \b /\b/ 空格
字符集
字符集使用
[]
表示的可能的字符的集合竿痰,集合內(nèi)部可以排列多個(gè)匹配字符串的可能性,整個(gè)字符需要匹配的是字符串中的一個(gè)字符砌溺。多選一的效果影涉。有一個(gè)滿(mǎn)足就匹配成功。-
簡(jiǎn)單類(lèi):
- 正則的多個(gè)字符對(duì)應(yīng)一個(gè)字符规伐,可以用[]把他們括起來(lái)蟹倾,只要在[]內(nèi)有一個(gè)滿(mǎn)足匹配條件就匹配成功。
- 例如:/[abc]/.test("erta") 表示只要包含abc三個(gè)字符的任意一個(gè)就匹配成功猖闪。
-
范圍類(lèi):
- 如果匹配的東西過(guò)多鲜棠,而且類(lèi)型又相同,可以在中間加個(gè)橫線(xiàn)培慌。[a-z]豁陆、[0-9]、[A-Z]
- 例如:/[0-9]/.test(""abc8) 表示匹配0-9之間的字符吵护,包含0-9盒音。
-
負(fù)向類(lèi):
- []前面加個(gè)元字符進(jìn)行取反竖配,表示匹配不能為括號(hào)里面的字符。取反里逆。
-
組合類(lèi):
- 允許用中括號(hào)匹配不同類(lèi)型的單個(gè)字符。[0-z]
修飾符
- g 修飾符用于執(zhí)行全局匹配用爪,查找所有匹配而非在找到第一個(gè)匹配后停止原押。
- "12z12b12c".match(/\d+/g) ==> ["12", "12", "12"]
- i 修飾符用于執(zhí)行對(duì)大小寫(xiě)不敏感的匹配。如果不配和
g
修飾符偎血,表示匹配到第一個(gè)字符就停止匹配诸衔,可以配合g
修飾符使用。- "12Ab".match(/[a-z]/gi) ==> ["A", "b"]
邊界
- ^ 表示以什么字符開(kāi)頭颇玷,如果在[]使用笨农,表示取反。
- /^a/.match("dfgabc")
- $ 表示以什么字符結(jié)尾帖渠。
預(yù)定義類(lèi)
- . 除了換行和回車(chē)之外的任意字符
- \d 數(shù)字字符
- \D 非數(shù)字字符
- \s 空白字符
- \S 非空白字符
- \w 單詞字符谒亦,所有的字母、數(shù)字和下劃線(xiàn)
- \W 非單詞字符
量詞
- {n} 硬性量詞 對(duì)應(yīng)零次或者n次
- 示例:/^\d{5}$/.test("123456")
- {n,m} 軟性量詞 至少出現(xiàn)n次但不超過(guò)m次空郊,使用的時(shí)候中間不能有空格
- 示例:/^\d{3,5}$/.test("123456")
- {n,} 軟性量詞 至少出現(xiàn)n次
- 示例:/^\d{3}$/.test("123456")
- ? 軟性量詞 出現(xiàn)零次或者一次
- 示例:/^\d?$/.test("1")
-
軟性量詞 出現(xiàn)零次或多次
- 示例:/^\d*$/.test("12345")
-
-
軟性量詞 出現(xiàn)一次或者多次份招,至少出現(xiàn)一次
- 示例:/^\d+$/.test("123")
-
分組
- 如果想獲取重復(fù)的多個(gè)字符,可以使用小括號(hào)進(jìn)行分組狞甚。
- 語(yǔ)法:/(abc){2}/.test("byebye")
或操作符
- 可以使用豎線(xiàn)
|
字符表示或者的關(guān)系 - 語(yǔ)法:
- /a|bcd/.test("bcdsga") 匹配a或bcd字符
- /(ab)+|(cd)+/ 匹配出現(xiàn)一次或多次的ab或者cd
分組的反向引用
反向引用標(biāo)識(shí)是對(duì)正則表達(dá)式中的匹配組捕獲的子字符串進(jìn)行編號(hào)锁摔,如果再表達(dá)式內(nèi)進(jìn)行引用,通過(guò)"\編號(hào)" 進(jìn)行引用哼审,如果在表達(dá)式外進(jìn)行引用谐腰,則通過(guò)"$編號(hào)"進(jìn)行引用。從1開(kāi)始計(jì)數(shù)涩盾。
-
示例:
- /(bye)\1/.test("byebye") ==> true
- /(bye)\1/.test("bye") ==> false
- '123456'.replace(/(/d{3})*(/d{3})/, '
1') ==> "456123"
- '123*456'.replace(/(/d{3})*(/d{3})/, function(match,
2) {return
1})
中文字符
- 匹配中文:[\u4e00-\u9fa5]