這兩天在用正則表達(dá)式搞一個(gè)稍微有點(diǎn)復(fù)雜的東西,但是不同瀏覽器之間的差異可浪費(fèi)了我不少的人參。
現(xiàn)在我把正則表達(dá)式在五大主流瀏覽器(IE、Firefox、Chrome、Safari、Opera,以當(dāng)前版本為準(zhǔn))之間的差異整理一下羅列出來,給大家,也算給我自己做一個(gè)備忘。
1、Firefox和Chrome會(huì)過度優(yōu)化在循環(huán)(以及其中內(nèi)嵌的函數(shù)定義)中創(chuàng)建的正則表達(dá)式,似乎它們在假設(shè)寫JavaScript的人會(huì)把正則表達(dá)式的構(gòu)建和賦值寫錯(cuò)地方。
復(fù)制代碼 代碼如下:
var r;
for(var i = 0; i 2; i++){
var x = /abc/g;
if(r)
document.write(r == x); // 第二個(gè)循環(huán)時(shí)Firefox和Chrome會(huì)輸出“true”
else
r = x;
}
2、如果你把一個(gè)有可能什么也不返回的函數(shù)作為第二個(gè)參數(shù)傳遞給replace方法,那么IE可能會(huì)直接刪除匹配的文本(在之前的測試中我總結(jié)的是Opera的行為比較獨(dú)特,現(xiàn)在看起來似乎是錯(cuò)誤的結(jié)論),而其它瀏覽器則是會(huì)將匹配的文本替換成“undefined”。
復(fù)制代碼 代碼如下:
document.write('123'.replace(/2/, function(){})); // IE會(huì)輸出“13”,而其它瀏覽器輸出“1undefined3”
3、如果使用new RegExp的形式創(chuàng)建正則表達(dá)式時(shí)使用一個(gè)已有的正則表達(dá)式實(shí)例作為參數(shù),那么大部分瀏覽器都會(huì)創(chuàng)建一個(gè)基本功能相同,但完全獨(dú)立的、全新的正則表達(dá)式實(shí)例;而Safari則會(huì)很干脆地返回作為參數(shù)的那個(gè)正則表達(dá)式實(shí)例。
復(fù)制代碼 代碼如下:
var r = /1/;
document.write(new RegExp(r) == r); // Safari會(huì)輸出“true”,而其它瀏覽器輸出為“false”
4、如果把一個(gè)“空”的正則表達(dá)式直接轉(zhuǎn)化成字符串,IE以外的瀏覽器都會(huì)得到“/(?:)/”,而IE會(huì)得到“//”——但從正則表達(dá)式上直接提取source屬性的時(shí)候,得到的都是空字符串。
復(fù)制代碼 代碼如下:
document.write(new RegExp('')); // IE輸出“//”,其它瀏覽器輸出“/(?:)/”
document.write(eval('' + new RegExp(''))) // IE輸出“undefined”,其它瀏覽器輸出“/(?:)/”
5、如果把一個(gè)包含斜線“/”的正則表達(dá)式直接轉(zhuǎn)化成字符串——以“new RegExp('/')”為例,只有Firefox和Opera會(huì)得到“/\//”,并且直接提取source屬性會(huì)得到“\/”;而其它瀏覽器則會(huì)得到“///”,且直接提取source屬性會(huì)得到“/”。
復(fù)制代碼 代碼如下:
document.write(new RegExp('/')); // Firefox和Opera輸出“/\//”,其它瀏覽器輸出“///”
document.write(eval('' + new RegExp('/'))) // Firefox和Opera輸出“/\//”,其它瀏覽器輸出“undefined”
6、如果在使用字面表達(dá)式來定義一個(gè)正則表達(dá)式時(shí),使用了無效的選項(xiàng)標(biāo)志(例如“/abc/n”),則Chrome和Safari會(huì)完全忽視此無效選項(xiàng)標(biāo)志(等同于“/abc/”),而在其它瀏覽器會(huì)導(dǎo)致語法錯(cuò)誤。
復(fù)制代碼 代碼如下:
document.write(/abc/n); // Chrome和Safari會(huì)輸出“/abc/”,其它瀏覽器中產(chǎn)生語法錯(cuò)誤
7、如果通過構(gòu)造器來創(chuàng)建正則表達(dá)式時(shí),為其指定選項(xiàng)標(biāo)志的(第二個(gè))字符串參數(shù)中包含了非有效標(biāo)志的字符,在Firefox中就會(huì)引起一個(gè)異常,而其它瀏覽器會(huì)將無效的部分忽略。
復(fù)制代碼 代碼如下:
document.write(new RegExp('1', 'n')); // Firefox中會(huì)引起一個(gè)異常,提示無效的標(biāo)志;而其它瀏覽器會(huì)輸出“/1/”
暫時(shí)就這些吧,發(fā)現(xiàn)新的再補(bǔ)上。
來自:http://www.cnblogs.com/NanaLich