javascript正則表達式中參數(shù)g(全局)的作用
更新時間:2010年11月11日 14:29:50 作者:
表達式加上參數(shù)g之后,表明可以進行全局匹配,注意這里可以的含義。
我們詳細描述:
1)對于表達式對象的exec方法,不加入g,則只返回第一個匹配,無論執(zhí)行多少次均是如此,如果加入g,則第一次執(zhí)行也返回第一個匹配,再執(zhí)行第二個匹配,依次類推。例如:
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,并不是說執(zhí)行exec方法就可以返回所有的匹配,而是說加入了g以后,可以通過某種方式得到所有的匹配,這里的“方式”對于exec而言,就是執(zhí)行這個方法即可。
2)對于表達式對象的test方法,加入g跟不加g沒有什么區(qū)別。
3)對于String對象的match方法,不加g,也只是返回第一個匹配,一直執(zhí)行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也是一樣的。
1)對于表達式對象的exec方法,不加入g,則只返回第一個匹配,無論執(zhí)行多少次均是如此,如果加入g,則第一次執(zhí)行也返回第一個匹配,再執(zhí)行第二個匹配,依次類推。例如:
復制代碼 代碼如下:
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,并不是說執(zhí)行exec方法就可以返回所有的匹配,而是說加入了g以后,可以通過某種方式得到所有的匹配,這里的“方式”對于exec而言,就是執(zhí)行這個方法即可。
2)對于表達式對象的test方法,加入g跟不加g沒有什么區(qū)別。
3)對于String對象的match方法,不加g,也只是返回第一個匹配,一直執(zhí)行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也是一樣的。
相關(guān)文章
JavaScript中String.prototype用法實例
這篇文章主要介紹了JavaScript中String.prototype用法,實例分析了prototype的功能及使用技巧,需要的朋友可以參考下2015-05-05用headjs來管理和加載js 提高網(wǎng)站加載速度
headjs其實是一整套的工具,本文介紹的是它其中的Javascript Loader功能。需要的朋友可以參考下2016-11-11javascript實現(xiàn)的動態(tài)文字變換
javascript實現(xiàn)的動態(tài)文字變換...2007-07-07