正则表达式中lastIndex参数对匹配结果有何深远影响?
- 内容介绍
- 文章标签
- 相关推荐
本文共计525个文字,预计阅读时间需要3分钟。
前言:今天遇到一个问题,使用正则表达式去检查同一字符串时,交换单引号和反引号,输出true和false。
具体步骤如下:
1.使用正则表达式`/\\[\\]/g`去匹配字符串中的单引号和反引号。
2.判断匹配结果是否为空,如果不为空,则输出true,否则输出false。
代码示例:
javascriptlet str=这是一个测试字符串,包含单引号'和反引号`;let reg=/\\[\\]/g;let lastIndex=0;while ((lastIndex=reg.exec(str)) !==null) { console.log(reg.lastIndex===lastIndex + 1);}
前言
今天遇到一个问题,用正则表达式去检查同一个字符串时,交替返回true和false。无奈之下,重新翻了翻权威指南,发现罪魁祸首原来是lastIndex。可在控制台尝试下
let reg = /[\d]/g //undefined reg.test(1) //true reg.test(1) //false
lastIndex
lastIndex在权威指南中是如下解释:它是一个可读/写的整数。如果匹配模式带有g修饰符,这个属性存储在整个字符串中下次索引的开始位置,这个属性会被exec()和test()用到。
本文共计525个文字,预计阅读时间需要3分钟。
前言:今天遇到一个问题,使用正则表达式去检查同一字符串时,交换单引号和反引号,输出true和false。
具体步骤如下:
1.使用正则表达式`/\\[\\]/g`去匹配字符串中的单引号和反引号。
2.判断匹配结果是否为空,如果不为空,则输出true,否则输出false。
代码示例:
javascriptlet str=这是一个测试字符串,包含单引号'和反引号`;let reg=/\\[\\]/g;let lastIndex=0;while ((lastIndex=reg.exec(str)) !==null) { console.log(reg.lastIndex===lastIndex + 1);}
前言
今天遇到一个问题,用正则表达式去检查同一个字符串时,交替返回true和false。无奈之下,重新翻了翻权威指南,发现罪魁祸首原来是lastIndex。可在控制台尝试下
let reg = /[\d]/g //undefined reg.test(1) //true reg.test(1) //false
lastIndex
lastIndex在权威指南中是如下解释:它是一个可读/写的整数。如果匹配模式带有g修饰符,这个属性存储在整个字符串中下次索引的开始位置,这个属性会被exec()和test()用到。

