周梦康 发表于 2014-06-08 2480 次浏览

使用正则表达式字面量和使用 RegExp 构造函数创建的正则表达式不一样。在 ECMAScript 3 中, 正则表达式字面量始终会共享同一个RegExp实例,而使用构造函数创建的每一个新RegExp实例都是一个新实例。来看下面的例子。

var re = null,
        i;
for (i=0; i < 10; i++){
    re = /cat/g;
    re.test("catastrophe");
}
for (i=0; i < 10; i++){
    re = new RegExp("cat", "g");
    re.test("catastrophe");
}

在第一个循环中,即使是循环体中指定的,但实际上只为 /cat/ 创建了一个 RegExp 实例。由于实例属性不会重置,所以在循环中再次调用 test() 方法会失败。这是因为第一次调用 test() 找到了"cat",但第二次调用是从索引为 3 的字符(上一次匹配的末尾)开始的,所以就找不到它了。由于会测试到字符串末尾,所以下一次再调用 test()就又从开头开始了。

第二个循环使用 RegExp 构造函数在每次循环中创建正则表达式。因为每次迭代都会创建一个新的 RegExp 实例,所以每次调用 test()都会返回 true

说这两种方式有区别,我修改了下,没看出匹配的次数有区别呀,区别在哪呢?

var re = null,
	b  = 0,
	c  = 0,
	tmp,
    i;
for (i=0; i < 10; i++){
    re = /cat/g;
    tmp = re.test("catastrophe");
    console.log(tmp);
    if(tmp){
    	b++ ;
    }
}
for (i=0; i < 10; i++){
    re = new RegExp("cat", "g");
    tmp = re.test("catastrophe");
    console.log(tmp);
    if(tmp){
    	c++;
    }
}
console.log(b,c);

ECMAScript 5 明确规定,使用正则表达式字面量必须像直接调用 RegExp 构造函数一样,每次都创建新的 RegExp 实例。所以两个都是10次。

评论列表