var code1='"a" + 2'; //表达式 varcode2='{a:2}'; //语句 alert(eval(code1)); //->'a2' alert(eval(code2)); //->undefined alert(eval('(' + code2 + ')')); //->[object Object]
可 以看到,对于对象声明语句来讲,仅仅是执行,并不能返回值。为了返回经常使用的“{}”这样的对象声明语句,必须用括号括住,以将其转换为表达式,才能返回其 值。这也是使用JSON来进行Ajax开发的基本原理之一。在例子中能够清楚的看到,第二个alert语句输出的是undefined,而第三个加了括号 后输出的是语句表示的对象。 javascript
var s='global'; //定义一个全局变量 function demo1(){ eval('var s="local"'); } demo1(); alert(s); //->global
很好理解,上面的demo1函数等价于:function demo1(){var s='local';},其中定义了一个局部变量s。 java
因此最后的输出是global并非什么奇怪的事情,毕竟你们都能很清楚的区分局部变量和全局变量。var s='function test(){return 1;}'; //一个函数定义语句 function demo2(){ eval(s); } demo2(); alert(test()); //->error:test is not defined
这是由于test函数在局部空间定义,demo2函数内能够访问到,外面就访问不到了。 浏览器
而在实际的Ajax开发中,有时咱们须要从服务器动态获取代码来执行,以减轻一次载入代码过多的问题,或者是一些代码是经过Javascript自身生成的,但愿用eval函数来使其执行。function loadCode(){ varcode=getCode(); eval(code); }
可见eval不可能在全局空间内执行,这就给开发带来了很多问题,也看到过不少人为此郁闷。 服务器
不过如今偶终于找到了解决办法,嘿嘿,能够同时兼容IE和Firefox,方法以下:var X2={} //my namespace:) X2.Eval=function(code){ if(!!(window.attachEvent && !window.opera)){ //ie execScript(code); }else{ //not ie window.eval(code); } }
如今若是要想在函数内定义全局代码,就能够经过调用X2.eval_r(code)方法,一个例子以下: 函数
var s='global'; function demo3(){ X2.Eval('var s="local"'); } demo3(); alert(s); //->'local'
可见,在demo3函数内从新定义了全局变量s=”local”。