您好,登录后才能下订单哦!
这篇文章主要讲解了“JavaScript中RegExp对象的方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript中RegExp对象的方法有哪些”吧!
语法:
RegExpObject.test(string)
参数说明:
参数描述
string必需参数。要检测的字符串。
例如,检测一个字符串是否已“abc”开头(忽略大小写):
/^abc/i.test("abcdef");
检测一个字符串是否全部为数字:
/^\d{1,}$/.test("123456789");
检测一个字符串是否是字母和数字的组合:
var pattern=new RegExp("^[0-9a-zA-Z]{1,}$");
alert(pattern.test("123abc"));//显示true
exec()方法
exec()方法用来检索字符串中与正则表达式匹配的值。
exec()方法返回一个数组,其中存放匹配的结果。如果未找到匹配的值,则返回null。
语法:
RegExpObject.exec(string)
参数说明:
参数描述
string必需参数。要检索的字符串。
与test()方法相比,exec()方法更加强大,功能也更加复杂。
当exec()找到了匹配的文本时,会返回一个结果数组。否则,返回null。此数组的第0个元素是与正则表达式相匹配的文本,第1个元素是与RegExpObject的第1个子表达式相匹配的文本(如果有的话),第2个元素是与RegExpObject的第2个子表达式相匹配的文本(如果有的话),以此类推。
除了数组元素和length属性之外,exec()方法还返回两个属性。index属性声明的是匹配文本的第一个字符的位置。input属性则存放的是被检索的字符串string。
但是,当RegExpObject是一个全局正则表达式(带有g修饰符)时,exec()的行为就稍微复杂一些,它会在RegExpObject的lastIndex属性指定的字符处开始检索字符串string。当exec()找到了与表达式相匹配的文本时,在匹配后,它将把RegExpObject的lastIndex属性设置为匹配文本的最后一个字符的下一个位置。
也就是说,可以通过反复调用exec()方法来遍历字符串中的所有匹配文本。当exec()再也找不到匹配的文本时,它将返回null,并把lastIndex属性重置为0。
JavaScript RegExp对象的方法有哪些
请看下面的代码:
var str="Itxueyuan's domain is www.itxueyuan.org.Welcome to itxueyuan!";
var pattern=new RegExp("itxueyuan","ig");
var i=1;
var result;
while(result=pattern.exec(str)){
alert(
"第"+i+"次匹配的字符串:"+result[0]+"\n"+
"所匹配的字符的起始位置:"+result.index+"\n"+
"第"+(++i)+"次匹配的的起始位置:"+pattern.lastIndex
);
}
compile()方法
compile()方法可以在脚本执行过程中编译正则表达式,也可以改变已有表达式。
语法:
RegExpObject.compile(regexp,modifier)
参数说明:
参数描述
regexp正则表达式。
modifier规定匹配的类型。"g"用于全局匹配,"i"用于区分大小写,"gi"用于全局区分大小写的匹配。
例如,在字符串中全局搜索"man",并用"person"替换。然后通过compile()方法,改变正则表达式,用"person"替换"man"或"woman",:
var str="Every man in the world!Every woman on earth!";
patt=/man/g;
str2=str.replace(patt,"person");
document.write(str2+"
");
patt=/(wo)?man/g;
patt.compile(patt);
str2=str.replace(patt,"person");
document.write(str2);
执行结果:
Every person in the world!Every woperson on earth!
Every person in the world!Every person on earth!
感谢各位的阅读,以上就是“JavaScript中RegExp对象的方法有哪些”的内容了,经过本文的学习后,相信大家对JavaScript中RegExp对象的方法有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。