RegExp構(gòu)造函數(shù)
在es5中效览,RegExp
構(gòu)造函數(shù)的參數(shù)有兩種情況
第一種,參數(shù)是字符串荡短,這時(shí)第二個(gè)參數(shù)表示正則表達(dá)式的修飾符(flag)丐枉。
var regex = new RegExp('xyz','i')
//等價(jià)于
var regex=/xyz/i;
第二種,參數(shù)是一個(gè)正則表達(dá)式掘托,這時(shí)返回一個(gè)原有正則表達(dá)式的拷貝瘦锹。
var regex=new RegExp(/xyz/i);
//等價(jià)于
var regex = new RegExp(/xyz/,'i');
但是es5不允許此時(shí)使用第二個(gè)參數(shù)添加修飾符,否則會(huì)報(bào)錯(cuò)。
var regex=new RegExp(/abc/ig,'i').flags
ES6 改變了這種行為沼本。如果RegExp
構(gòu)造函數(shù)第一個(gè)參數(shù)是一個(gè)正則對(duì)象噩峦,那么可以使用第二個(gè)參數(shù)指定修飾符。而且抽兆,返回的正則表達(dá)式會(huì)忽略原有的正則表達(dá)式的修飾符,只使用新指定的修飾符族淮。
y修飾符
es6位正則表達(dá)式添加了y
修飾符,叫做"粘連"(sticky)修飾符辫红。
y
修飾符的作用與g
修飾符類似,也是全局匹配祝辣,后一次匹配都是從上一次匹配成功的下一個(gè)位置開(kāi)始贴妻。但y
修飾符確保匹配必須從剩余的第一個(gè)位置開(kāi)始,這也就是"粘連"的涵義蝙斜。
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
stick 屬性
與y
修飾符相匹配名惩,es6的正則對(duì)象多了sticky
屬性,表示是否設(shè)置了y
修飾符孕荠。
var r=/hello\d/y;
r.sticky
flags 屬性
es6為正則表達(dá)式新增了flags
屬性娩鹉,會(huì)返回正則表達(dá)式,會(huì)返回正則表達(dá)式的修飾符稚伍。
// es5 的 source 屬性
// 返回正則表達(dá)式的正文
/abc/ig.source
// "abc"
// es6 的 flags 屬性
// 返回正則表達(dá)式的修飾符
/abc/ig.flags
// 'gu'
后行斷言
javascript 語(yǔ)言的正則表達(dá)式弯予,只支持先行斷言( lookhead )和先行否定斷言( negative lookhead ),不支持后行斷言( lookbehind )和后行否定斷言( negative lookbehind )。目前个曙,有一個(gè)提案锈嫩,引入后行斷言,v8引擎 4.9版已經(jīng)支持垦搬。
"先行斷言"指的是呼寸,x
只有在y
前面才匹配,必須寫成/x(?=y)/
猴贰。比如对雪,只匹配百分號(hào)之前的數(shù)字,要寫成/\d+(?=%)
糟趾。"先行否定斷言"指的是慌植,x
只有不在y
前面才匹配,必須寫成/x(?!y)/
义郑。比如蝶柿,職匹配不在百分號(hào)之前的數(shù)字,要寫成/\d+(?!%)/
非驮。
/\d+(?=%)/.exec('100% of US presidents have been male') // ["100"]
/\d+(?!%)/.exec('that’s all 44 of them') // ["44"]
“后行斷言”正好與“先行斷言”相反交汤,x
只有在y
后面才匹配,必須寫成/(?<=y)x/
。比如芙扎,只匹配美元符號(hào)之后的數(shù)字星岗,要寫成/(?<=\$)\d+/
〗渫荩”后行否定斷言“則與”先行否定斷言“相反俏橘,x
只有不在y
后面才匹配,必須寫成/(?<!y)x/
圈浇。比如寥掐,只匹配不在美元符號(hào)后面的數(shù)字,要寫成/(?<!\$)\d+/
磷蜀。
/(?<=\$)\d+/.exec('Benjamin Franklin is on the $100 bill') // ["100"]
/(?<!\$)\d+/.exec('it’s is worth about €90') // ["90"]