为什么80%的码农都做不了架构师?>>>
一、eval() 动态执行时使用当前函数的闭包。
var i = 100;
function myFunc(ctx) {var i = 'test';eval('var test = "hello."'); //test执行后为局部变量
}
myFunc();
// 输出值100
alert(i);
二、eva l() 访问全局闭包:
1、IE内核环境下:
在 Internet Explorer 中的 JScript 的 eva l() 下,无 论是使用 window.eva l 调用,还是使用 window 作为传入的 this 实例,都不可能让 eva l() 得到访问全局闭包的能力。不过 JScript 中可以使用另一种方法来 得到完全相同的效果,即在 window.execScript() 方法中执行的代码“总是”在 全局闭包中执行。
// 本例建议在Internet Explorer 环境中测试
var i = 100;
function myFunc() {window.execScript('i = "test"');//execScript('i = "test"');
}
myFunc();
// 输出值'test', 表明调用myFunc()时修改了全局闭包中的变量i
alert(i);
而且, JScript 运行在名为 ActiveScript 的脚本环境中,该 execScript() 方法也提 供跨脚本语言的代码能力。因此也可以在第二个参数中指定语言的种类。
execScript('i = "test"', 'JScript');
或
execScript('dim i = "test"', 'VBScript');
2、非 IE内核环境下:
// 本例建议在mozilla firefox 环境中测试
var i = 100;
function myFunc() {window.eval('i = "test"');//eval.call(window, 'i = "test"');
}
myFunc();
// 输出值'test', 表明调用myFunc()时修改了全局闭包中的变量i
alert(i);
三、解决eval作用域的方法: with ( objContext )eval (strScript) 。
with ( window )eval (strScript) ; //eval在 全局作用域中执行
四、使 用eval()来获取“对象直接量”:
// 用eval()来获取“对象直接量”的正确方法, 返回对象
alert( eval('({ name: "MyName", value: 1 })' )); //注意外层的括号({ name: "MyName",value: 1 })
五、使用eval() 获取匿名函数:
var func = eval(' (function() { })');
// 输出'undefined'
alert(typeof func);
var func;
eval( 'function func() { }' );
// 输出'function'
alert(typeof func);
必须使用匿名函数的情况:
//var func = eval(' (function() { }).prototype.constructor ');
//var func = eval('( {$:function() { }}).$');
// 或
var func = eval(' [function() { }][0]');
// 输出'function'
alert(typeof func);