附件参数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,
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