什么是 RegExp?
正则表达式描述了字符的模式对象。
当您检索某个文本时,可以使用一种模式来描述要检索的内容。RegExp 就是这种模式。
简单的模式可以是一个单独的字符。
更复杂的模式包括了更多的字符,并可用于解析、格式检查、替换等等。
您可以规定字符串中的检索位置,以及要检索的字符类型,等等。
RegExp对象是原生JavaScript中表示正则表达式的对象。
创建对象的方法为:var RegExp = new RegExp(pattern, attributes);
参数pattern指定正则表达式的规则或者表示正则表达式模式的字符串;
参数attributes为可选参数,表示匹配模式的修饰符。包含3个参数:
1. i:执行对大小写不敏感匹配;
<script text="text/javascript"> var txt = 'Hello World!' var reg = new RegExp('hello', 'i'); if(reg.test(txt)) { console.log(txt.match(reg)); } </script>
2. g:执行全局匹配(查找所有匹配项而非找到第一个匹配项后停止);
<script text="text/javascript"> var txt = 'This is just a test.' var reg = new RegExp('is', 'g');//区分大小写 var reg01 = new RegExp('is', 'gi');//不区分大小写 if(reg.test(txt)) { console.log(txt.match(reg));//["is", "is"] console.log(txt.match(reg).length);//2 } </script>
3. m:执行多行匹配(若不设置该属性,^($)只与整个被搜索字符串的开始(结尾)位置开始匹配;若设置该属性,^($)还可以与被搜索字符串的“\r”或“\n”之后位置开始匹配)。
<script type="text/javascript"> //以下代码不能够匹配字符串"an",尽管"an"后面已经换行了,但"an"并不是字符串行的结尾。 var txt1 = 'This is an\n apple'; var reg1 = /an$/; console.log(txt1.match(reg1));//null //以下代码能够匹配到字符串"an" var txt2 = 'This is an\n apple'; var reg2 = /an$/m; console.log(txt2.match(reg2));//["an", index: 8, input: "This is an"] //以下是多行匹配开头示例 var txt3 = 'This is an\n apple'; var reg3 = /^\sapp/; console.log(txt3.match(reg3));//null var txt4 = 'This is an\n apple'; var reg4 = /^\sapp/m;// /^ app/m console.log(txt4.match(reg4));//[" app", index: 11, input: "This is an"] </script>
i,g,m三个修饰符可以相互组合同时使用。
以上m修饰符中的示例中var reg4 = /^\sapp/的"\"是一个转义字符,如果使用构造函数创建RegExp对象时,应将正则表达式中的"\"用"\\"进行代替:
<script type="text/javascript"> var txt4 = 'This is an\n apple'; var reg4 = new RegExp('^\\sapp', 'm'); console.log(txt4.match(reg4));//[" app", index: 11, input: "This is an"] </script>
RegExp对象属性
1.global
返回正则表达式是否具有"g"修饰符;
<script type="text/javascript"> var txt = 'This is just a test'; var reg = new RegExp('st', 'g'); if(reg.global) { console.log(txt.match(reg));//["st", "st"] } </script>
2.ignoreCase
返回正则表达式是否具有"i"修饰符;
3.multiline
返回正则表达式是否具有"m"修饰符;
4.lastIndex
标记下一次匹配开始时所在字符串的位置;
<script type="text/javascript"> var txt = 'If you love code, you should code everyday.'; var reg = new RegExp('ou', 'g'); var length = txt.match(reg).length; for(var i = 0; i < length; i++) { reg.test(txt); console.log(reg.lastIndex); } </script>
5.source
返回正则表达式进行模式匹配的文本或表达式,返回的文本中不包括修饰符"i","g","m",也不包括正则表达式直接量使用的定界符
<script> var reg1 = new RegExp('yoho', 'm'); var reg2 = new RegExp('\\w'); var reg3 = /\w/m; console.log(reg1.source);//yoho console.log(reg2.source);//\w console.log(reg3.source);//\w </script>
RegExp对象方法
1.compile
改变或重新编译正则表达式(Opera浏览器不支持该方法)
对于正则表达式的重新定义,以下方法就可以实现,所以对于此方法的应用场景,我也不是很清楚
<script> var reg = new RegExp('ou', 'g'); reg = /\w/; </script>
2.exec
检索字符串中正则表达式的匹配结果
<script> var txt = 'If you love code, you should code everyday.'; var reg = new RegExp('ou', 'g'); var length = txt.match(reg).length; for(var i = 0; i < length; i++) { console.log(reg.exec(txt)); } </script>
3.test
检测字符串是否与匹配正则表达式匹配
<script> var txt = 'I code everyday.'; var reg = new RegExp('code'); console.log(reg.test(txt));//true </script>
以上所述是小编给大家介绍的JavaScript RegExp对象,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]