题主先试试在Chrome的console里对比一下这四段代码:
for (var i = 1; i <= 10; i++) { console.time(i); for (var j = 0; j <256*256*256; j++) { }; console.timeEnd(i); } /* or the version below eval("for (var i = 1; i <= 10; i++) { console.time(i); for (var j = 0; j <256*256*256; j++) { }; console.timeEnd(i); }") */
和:
function foo() { eval("for (var i = 1; i <= 10; i++) { console.time(i); for (var j = 0; j <256*256*256; j++) { }; console.timeEnd(i); }") } foo()
还有:
function foo() { (0,eval)("for (var i = 1; i <= 10; i++) { console.time(i); for (var j = 0; j <256*256*256; j++) { }; console.timeEnd(i); }") } foo()
最后:
function foo() { for (var i = 1; i <= 10; i++) { console.time(i); for (var j = 0; j <256*256*256; j++) { }; console.timeEnd(i); } } foo()
有没有惊喜?
在我的本上跑,
恭喜题主中了eval大招…细节解释起来略麻烦。回头有空再说…