javascript正则表达式中参数g(全局)的作用_javascript技巧
程序员文章站
2024-01-14 12:10:40
...
我们详细描述:
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也是一样的。
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也是一样的。
上一篇: 浅谈MySQL分页Limit的性能问题
下一篇: EFCore某张表中获取某几个字段
推荐阅读
-
javascript正则表达式中参数g(全局)的作用_javascript技巧
-
JavaScript 参数中的数组展开 [译]_javascript技巧
-
javascript提取URL的搜索字符串中的参数(自定义函数实现)_javascript技巧
-
Javascript 函数中的参数使用分析_javascript技巧
-
JavaScript中全局变量、函数内变量以及常量表达式的效率测试_javascript技巧
-
深入理解Javascript中this的作用域_javascript技巧
-
javascript中bind函数的作用实例介绍_javascript技巧
-
JS中setInterval、setTimeout不能传递带参数的函数的解决方案_javascript技巧
-
深入解析JavaScript中的变量作用域_javascript技巧
-
javascript正则表达式标记中/g /i /m的用法,以及实例