javascript正則表達式中參數(shù)g(全局)的作用
更新時間:2010年11月11日 14:29:50 作者:
表達式加上參數(shù)g之后,表明可以進行全局匹配,注意這里可以的含義。
我們詳細(xì)描述:
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},當(dāng)sep=/user\d/g,返回值也是一樣的。
6)對于string對象的search方法,加不加g也是一樣的。
1)對于表達式對象的exec方法,不加入g,則只返回第一個匹配,無論執(zhí)行多少次均是如此,如果加入g,則第一次執(zhí)行也返回第一個匹配,再執(zhí)行第二個匹配,依次類推。例如:
復(fù)制代碼 代碼如下:
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,則一次返回所有的匹配。例如:
復(fù)制代碼 代碼如下:
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是一樣的,即:
復(fù)制代碼 代碼如下:
var sep=/user\d/;
var array=”user1dfsfuser2dfsf”.split(sep);
則array的值為{dfsf,dfsf},當(dāng)sep=/user\d/g,返回值也是一樣的。
6)對于string對象的search方法,加不加g也是一樣的。
相關(guān)文章
用JS提交參數(shù)創(chuàng)建form表單在FireFox中遇到的問題
在一個前端頁面上,需要通過JavaScript來提交參數(shù),使用JS創(chuàng)建form表單,將參數(shù)append到表單中進行提交,接下來將介紹如何操作與實現(xiàn)2013-01-01
asp javascript 實現(xiàn)關(guān)閉窗口時保存數(shù)據(jù)的辦法
asp javascript 實現(xiàn)關(guān)閉窗口時保存數(shù)據(jù)的辦法...2007-11-11
Javascript中的回調(diào)函數(shù)和匿名函數(shù)的回調(diào)示例介紹
這篇文章主要介紹了Javascript中的回調(diào)函數(shù)和匿名函數(shù)的回調(diào),需要的朋友可以參考下2014-05-05
基于js實現(xiàn)的限制文本框只可以輸入數(shù)字
本文主要介紹了js限制文本框只可以輸入數(shù)字的實例代碼,可復(fù)制直接調(diào)用函數(shù)實現(xiàn)其功能。需要的朋友可以看下2016-12-12
JS實現(xiàn)頁面鼠標(biāo)點擊出現(xiàn)圖片特效
這篇文章主要為大家詳細(xì)介紹了JS實現(xiàn)頁面鼠標(biāo)點擊出現(xiàn)圖片特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-08-08
解析element-ui中upload組件傳遞文件及其他參數(shù)的問題
這篇文章主要介紹了element-ui中upload組件如何傳遞文件及其他參數(shù),分析一下我使用element-ui遇到的問題以及解決方法,需要的朋友可以參考下2021-11-11

