当我使用全局标志和大小写不敏感标志时,这个正则表达式有什么问题?查询是用户生成的输入。结果应该是[真,真]。

var query = 'Foo B';
var re = new RegExp(query, 'gi');
var result = [];
result.push(re.test('Foo Bar'));
result.push(re.test('Foo Bar'));
// result will be [true, false]

var reg = /^a$/g; for(i = 0; i++ < 10;) console.log(reg.test(“a”));


当前回答

你需要设置re.lastIndex = 0,因为带有g标志的regex会跟踪最近发生的匹配,所以test不会去测试相同的字符串,为此你需要执行re.lastIndex = 0

var query = 'Foo B'; var re = new RegExp(查询,'gi'); Var结果= []; result.push(再保险。测试(Foo酒吧)); re.lastIndex = 0; result.push(再保险。测试(Foo酒吧)); console.log(结果)

其他回答

删除全局g标志将解决您的问题。

var re = new RegExp(query, 'gi');

应该是

var re = new RegExp(query, 'i');

您正在使用一个RegExp对象并多次执行它。在每次连续执行时,它都从最后一个匹配索引开始。

你需要在每次执行前“重置”正则表达式,从头开始:

result.push(re.test('Foo Bar'));
re.lastIndex = 0;
result.push(re.test('Foo Bar'));
// result is now [true, true]

话虽如此,每次创建一个新的RegExp对象可能更具可读性(开销很小,因为RegExp是缓存的):

result.push((/Foo B/gi).test(stringA));
result.push((/Foo B/gi).test(stringB));

test更新正则表达式的lastIndex属性,以便每次测试都从上次测试停止的位置开始。我建议使用String.prototype.match,因为它不会更新lastIndex属性:

!!'Foo Bar'.match(re); // -> true
!!'Foo Bar'.match(re); // -> true

注意:! !将其转换为布尔值,然后反转布尔值,以反映结果。

或者,你可以重置lastIndex属性:

result.push(re.test('Foo Bar'));
re.lastIndex = 0;
result.push(re.test('Foo Bar'));

你需要设置re.lastIndex = 0,因为带有g标志的regex会跟踪最近发生的匹配,所以test不会去测试相同的字符串,为此你需要执行re.lastIndex = 0

var query = 'Foo B'; var re = new RegExp(查询,'gi'); Var结果= []; result.push(再保险。测试(Foo酒吧)); re.lastIndex = 0; result.push(再保险。测试(Foo酒吧)); console.log(结果)

使用/g标志告诉它在命中后继续搜索。

如果匹配成功,exec()方法返回一个数组并更新正则表达式对象的属性。

在你第一次搜索之前:

myRegex.lastIndex
//is 0

第一次搜索之后

myRegex.lastIndex
//is 8

删除g,它将在每次调用exec()后退出搜索。