正则表达式中附加参数的用法

前端之家收集整理的这篇文章主要介绍了正则表达式中附加参数的用法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
附件参数g的用法
1)对于表达式对象的exec方法,不加入g,则只返回第一个匹配,无论执行多少次均是如此,如果加入g,则第一次执行也返回第一个匹配,再执行返回第二个匹配
function validate()
{
var regx=/user/d/;
var str="user18dsdfuser2dsfsduser3";
var rs=regx.exec(str);
var rs2=regx.exec(str);
var rs3 = regx.exec(str);
alert(rs+" "+rs2+" "+rs3);
}
<input name="" type="button" onclick="validate();" />
结果为:user1 user1 user1

改为:var regx=/user/d/g;
结果为:user1 user2 user3
2)对于表达式对象的test方法,加入g于不加上g没有什么区别。
3)对于String对象的match方法,不加入g,也只是返回第一个匹配,一直执行match方法也总是返回第一个匹配,加入g,
则一次返回所有的匹配(注意这与表达式对象的exec方法不同,对于exec而言,表达式即使加上了g,也不会一次返回所有的匹配) 4)对于String对象的replace方法,表达式不加入g,则只替换第一个匹配,如果加入g,则替换所有匹配。 function validate() { var regx=/user/d/g; var str="user18dsdfuser2dsfsduser3"; var rs=str.replace(regx,"teacher1"); alert(rs); } 5)对于String对象的split方法加上g与不加g是一样的 6)对于String对象的search方法,加不加g也是一样的 附加参数m的用法 附加参数m,表明可以进行多行匹配,但是这个只有当使用^和$模式时才会起作用,在其他的模式中,加不加入m都可以进行多行匹配(其实说多行的字符串也是一个普通字符串) 在页面上放一个TextArea文本域 function validate() { var regx=/^user/d/g; var str=document.getElementById("txt1").value; var rs=str.match(regx); alert(rs); } 在文本域里输入: dsafasd user1kkasjfas gsdfasuser2 user3asdf 结果为null,因为只在第一行找user/d 改为:var regx=/^user/d/gm; 结果为:user1 user3

猜你在找的正则表达式相关文章