我有这段代码:
function func1(text) {
var pattern = /([\s\S]*?)(\<\?(?:attrib |if |else-if |else|end-if|search |for |end-for)[\s\S]*?\?\>)/g;
var result;
while (result = pattern.exec(text)) {
if (some condition) {
throw new Error('failed');
}
...
}
}
除非执行 throw 语句,否则这是有效的。在这种情况下,下次我调用该函数时, exec() 调用将从它停止的地方开始,即使我为其提供了新的“文本”值。
我可以通过写来修复它
var 模式 = new RegExp('.....');
相反,但我不明白为什么第一个版本失败了。正则表达式如何在函数调用之间保持不变? (这种情况发生在最新版本的 Firefox 和 Chrome 中。)
Edit完整的测试用例:
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-type" content="text/html;charset=UTF-8">
<title>Test Page</title>
<style type='text/css'>
body {
font-family: sans-serif;
}
#log p {
margin: 0;
padding: 0;
}
</style>
<script type='text/javascript'>
function func1(text, count) {
var pattern = /(one|two|three|four|five|six|seven|eight)/g;
log("func1");
var result;
while (result = pattern.exec(text)) {
log("result[0] = " + result[0] + ", pattern.index = " + pattern.index);
if (--count <= 0) {
throw "Error";
}
}
}
function go() {
try { func1("one two three four five six seven eight", 3); } catch (e) { }
try { func1("one two three four five six seven eight", 2); } catch (e) { }
try { func1("one two three four five six seven eight", 99); } catch (e) { }
try { func1("one two three four five six seven eight", 2); } catch (e) { }
}
function log(msg) {
var log = document.getElementById('log');
var p = document.createElement('p');
p.innerHTML = msg;
log.appendChild(p);
}
</script>
</head>
<body><div>
<input type='button' id='btnGo' value='Go' onclick='go();'>
<hr>
<div id='log'></div>
</div></body>
</html>
在 FF 和 Chrome 上第二次调用时,正则表达式以“4”继续,在 IE7 或 Opera 上则不然。
通过正则表达式文字创建的 RegExp 对象会被缓存,但是new RegExp
总是创建一个新对象。缓存的对象也保存它们的状态,但是管理这方面的规则显然不是很清楚。史蒂夫·莱维森 (Steve Levithan) 在这篇博文 http://blog.stevenlevithan.com/archives/fixing-javascript-regexp(靠近底部)。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)