5

http://jsfiddle.net/bpt33/

var t = "";

var a = ["atom-required","atom-label","atom-data-type","atom-regex"];

var r = /atom\-(label|required|regex|data\-type|class|is\-valid|field\-value|error)/i;

function test(a, r){
    for(var i = 0; i<a.length; i++){
        t += a[i] + " => " + r.test(a[i]) + "<br/>";
    }
}

test(a, r);

t += "<br/>";

a = ["atom-required","atom-label","atom-data-type","atom-regex"];

var r = /atom\-(label|required|regex|data\-type|class|is\-valid|field\-value|error)/gi;

test(a, r);

$("#results").get(0).innerHTML = t;

当不指定 g 时,它可以正常工作,

atom-required => true
atom-label => true
atom-data-type => true
atom-regex => true

当指定 g 时,它会交替工作

atom-required => true
atom-label => false
atom-data-type => true
atom-regex => false
4

1 回答 1

11

因为有了g修饰符,正则表达式变为有状态的,并在最后一次匹配后的索引处恢复下一次搜索。

当没有找到匹配项时,它会自行重置。

.lastIndex您可以使用该属性观察起点。

r.lastIndex; // 0 or some higher index

您可以通过将该属性设置为 来手动重置它0

r.lastIndex = 0
于 2013-06-09T20:04:41.600 回答