相同点:
(1)execScript与eval都可以接收一个字符串,若该字符串是表达式(expression),则执行时将求得该表达式的值并返回;若该字符串是一个或多个语句(statements),则执行时将运行这些语句。
不同点:
(1)execScript是IE浏览器独有;eval则是所有浏览器都支持。
(2)execScript无论是在什么作用域(global/local)内被调用,它所接受到的表达式(expression)或语句(statements)字符串都将在全局作用域内执行(global);eval则是在它被调用时所在的作用域内运行它所接受到的表达式(expression)或语句(statements)字符串。
先看看eval例子
eval('var global = "global";');//全局作用域内调用eval,则var global = "global";是在全局作用域内被运行的,最终是得到一个global全局变量
(function(){
//这个匿名函数块内生成了一个局部作用域
eval('var local = "local";');//局部作用域内调用eval,则var local = "local";是在局部作用域内被运行的,最终是得到一个local局部变量
console.log(local);//输出local
console.log(global);//输出global,因为它是全局变量
})();
console.log(global);//输出global
console.log(local);//报错,提示local为声明,因为local是局部变量,外部无法访问
再看看execScript例子
//注意,以下代码必须在IE浏览器下运行
execScript('var global = "global";');//这里声明并初始化了一个global全局变量
(function(){
//这个匿名函数块内生成了一个局部作用域
execScript('var local = "local";');//这里其实还是声明并初始化了一个local的全局变量,不要误认为local是一个局部变量哦。
alert(local);//输出local
alert(global);//输出global
})();
alert(local);//输出local
alert(global);//输出global
那么如何在不支持execScript函数的浏览器下实现在全局作用内执行字符串呢?这里列出jQuery的实现,其实还是蛮简单的,具体如下:
function globalEval( data ) {
if ( data ) {
// We use execScript on Internet Explorer
// We use an anonymous function so that context is window
// rather than jQuery in Firefox
( window.execScript || function( data ) {
window[ "eval" ].call( window, data );
} )( data );
}
}