浅谈 js eval作用域

作者:乱码. 来源:cnblogs.com 发布时间:2014-08-01 查看数:50472

当执行JavaScript代码时,JavaScript引擎会创建一个执行上下文(Execution Context)。该上下文即是我们常说的作用域,理解JavaScript的作用域很重要,本文介绍在EVAL中的作用域情况。

首先我们看如下代码

var x = 1;
(function () {
    eval('var x = 123;');
})();
console.log(x);

这个代码得到的是 1 而不是 123

如果想让 eval 执行的代码是全局的,那么有几种方法

var x = 1;
(function () {
    window.eval('var x = 123;');
})();
console.log(x);

这个方法标准浏览器都可以得到 123 而IE6-8则依然是 1

相同的例如

var arr = [0,0,0,0,0,0];
(function () {
    var arr = [1,1,1,1,1,1];
    var _eval = eval;
    window.eval('arr[0] = 123;');
    eval.call(null, 'arr[1] = 123;');
    _eval('arr[2] = 123;');
    (0,eval)('arr[3] = 123;');
})();
console.log(arr);

0,1 貌似不支持IE8- 2,3 貌似不支持 IE7-

反正归根结底就是兼容性有问题。

不过还在IE下有个 execScript 非常好使。

var x = 1;
(function () {
    (!-[1,] ? execScript : eval)('var x = 123;');
})();
console.log(x);

这样基本上就全兼容了。

\

本文作者:乱码

原文地址:http://www.cnblogs.com/52cik/p/js-eval.html