码迷,mamicode.com
首页 > 其他好文 > 详细

循环下正则匹配的问题

时间:2018-09-13 15:07:00      阅读:138      评论:0      收藏:0      [点我收藏+]

标签:字符串   第一个字符   规则   http   没有   bsp   位置   就会   return   

最近在使用正则的时候,遇到一个奇怪的现象,代码如下

const reg = /\.jpg/g;
const arr = ["test1.jpg", "test2.jpg", "test3.jpg", "test4.jpg"];

arr.map(item => console.log(reg.test(item)));

代码非常简单,就是循环匹配校验图片后缀名,看一下运行结果

技术分享图片

结果并没有达到预期的结果,结果不是全是true, 而是交替打印的true 和false

为什么会这样?

首先正则有一个属性叫  lastIndex,表示正则下一次匹配的起始位置,一般情况下是用不到它的,但是在正则中包含全局标志 g,使用 test 和 exec 方法时就会用到它,具体规则:

  • 初始状态下 lastIndex 的值为 0
  • 若匹配成功,lastIndex的值就被更新成被匹配字符串后面的第一个字符的index,也就是被匹配字符串的最后一个 index + 1
  • 若匹配失败,lastIndex 被重置为 0
  • 如果我们继续使用原先的正则匹配下一轮,则会从字符串lastIndex的位置开始匹配

下面我们来打印一下 lastIndex

技术分享图片

明白的lastIndex的规则,解决办法就很明显了

1. 在正则中去掉全局标志 g

const reg = /\.jpg/;
arr = [‘test1.jpg‘, ‘test2.jpg‘, ‘test3.jpg‘, ‘test4.jpg‘];
arr.map(item
=> console.log(reg.test(item)));

2. 就是每次匹配之后都将 lastIndex 置为 0

const reg = /\.jpg/g;
var arr = [‘test1.jpg‘, ‘test2.jpg‘, ‘test3.jpg‘, ‘test4.jpg‘];

arr.map(item => {
    console.log(reg.test(item));
    reg.lastIndex = 0;
    return item;
});

 

循环下正则匹配的问题

标签:字符串   第一个字符   规则   http   没有   bsp   位置   就会   return   

原文地址:https://www.cnblogs.com/shenjp/p/9640439.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!