我們詳細描述:
1)對於表達式對象的exec方法,不加入g,則只返回第一個匹配,無論執行多少次均是如此,如果加入g,則第一次執行也返回第一個匹配,再執行第二個匹配,依次類推。例如:
復制代碼 代碼如下:
var regx=/user\d/;
var str=”user18duser2dsc”;
var rs=regx.exec(str);//此時rs的值為{user1}
var rs2=regx.exec(str);//此時rs的值依然是{user1}
如果regx=/user\d/g:則rs的值為{user1},rs2的值為{user2}
通過這個例子說明:對於exec方法,表達式加入了g,並不是說執行exec方法就可以返回所有的匹配,而是說加入了g以後,可以通過某種方式得到所有的匹配,這裡的“方式”對於exec而言,就是執行這個方法即可。
2)對於表達式對象的test方法,加入g跟不加g沒有什麼區別。
3)對於String對象的match方法,不加g,也只是返回第一個匹配,一直執行match方法也總是返回第一個匹配,加入g,則一次返回所有的匹配。例如:
復制代碼 代碼如下:
var regx=/user\d/;
var str=”user1dge3user2gwe”;
var rs=str.match(regx);//此時rs的值為{user1}
var rs2=str.match(regx);//此時rs2的值依然為{user1}
如果regx=/user\d/g,則rs的值為{user1,user2},rs2的值也為{user1,user2}
4)對於string對象的replace方法,表達式不加g,則只替換第一個匹配,如果加入g,則替換所有匹配。
5)對於String對象的split方法,加上g與不加g是一樣的,即:
復制代碼 代碼如下:
var sep=/user\d/;
var array=”user1dfsfuser2dfsf”.split(sep);
則array的值為{dfsf,dfsf},當sep=/user\d/g,返回值也是一樣的。
6)對於string對象的search方法,加不加g也是一樣的。