浅谈 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