字符串的正則方法
字符串對象共有 4 個方法,可以使用正則表達式:match()、replace()、search()和 split()。
ES6 將這 4 個方法,在語言內(nèi)部全部調(diào)用 RegExp 的實例方法,從而做到所有與正則相關的方法,全都定義在 RegExp 對象上。
- String.prototype.match 調(diào)用 RegExp.prototype[Symbol.match]
- String.prototype.replace 調(diào)用 RegExp.prototype[Symbol.replace]
- String.prototype.search 調(diào)用 RegExp.prototype[Symbol.search]
- String.prototype.split 調(diào)用 RegExp.prototype[Symbol.split]
不過對于使用者來說,基本沒有什么變化
正則的修飾符
type | 作用 |
---|---|
i | 表示忽略大小寫,默認區(qū)分大小寫 |
g | 表示匹配所有的,默認是匹配到第一個就停下 |
u | 含義為“Unicode 模式”,用來正確處理大于\uFFFF 的 Unicode 字符。也就是說,會正確處理四個字節(jié)的 UTF-16 編碼。 |
y | 也是全局匹配,后一次匹配都從上一次匹配成功的下一個位置開始 |
s | dotAll 修飾符(點修飾符),開啟一種模式,這種模式下 . 可以用來表示任意字符 |
特別的
y 修飾符的作用與 g 修飾符類似,也是全局匹配,后一次匹配都從上一次匹配成功的下一個位置開始。不同之處在于,g 修飾符只要剩余位置中存在匹配就可,而 y 修飾符確保匹配必須從剩余的第一個位置開始,這也就是“粘連”的涵義。
var s = "aaa_aa_a";
var r1 = /a+/g;
var r2 = /a+/y;
r1.exec(s); // ["aaa"]
r2.exec(s); // ["aaa"]
r1.exec(s); // ["aa"]
r2.exec(s); // null
上面代碼有兩個正則表達式,一個使用 g 修飾符,另一個使用 y 修飾符。這兩個正則表達式各執(zhí)行了兩次,第一次執(zhí)行的時候,兩者行為相同,剩余字符串都是_aa_a。由于 g 修飾沒有位置要求,所以第二次執(zhí)行會返回結果,而 y 修飾符要求匹配必須從頭部開始,所以返回 null。
通俗的說就是, g 只要后面的字符還有能滿足正則的一段就會表示匹配,然后 y 就要求必須從上一個滿足的下一個字符開始的字符必須滿足正則才會顯示匹配
RegExp.prototype 的屬性
屬性 | 作用 |
---|---|
unicode | 表示是否設置了 u 修飾符 |
sticky | 表示是否設置了 y 修飾符。 |
flags | 會返回正則表達式的修飾符。 |
source | 會返回正則表達式的表達式。 |
斷言
type | 形式 | 作用 | 版本 |
---|---|---|---|
先行斷言 | /x(?=y)/ | x 只有在 y 前面才匹配 | |
先行否定斷言 | /x(?!y)/ | x 只有不在 y 前面才匹配 | |
后行斷言 | /(?<=y)x/ | x 只有在 y 后面才匹配 | 2018 |
后行否定斷言 | /x(?<!y)/ | x 只有不在 y 后面才匹配 | 2018 |
-----------------未完待續(xù)--------------
回到目錄