eval與window.eval的差別分析
更新時(shí)間:2011年03月17日 00:13:52 作者:
eval與window.eval的差別分析,學(xué)習(xí)js的朋友可以了解下。
它們之間有區(qū)別嗎?
開發(fā)過(guò)程中似乎很少有人去加個(gè)額外的window,覺(jué)得多此一舉。比如Ajax過(guò)程中回調(diào)函數(shù)解析JSON格式字符串
...
function callback(str){
var json = eval('(' + str + ')');
}
...
通常直接使用eval,而非var json = window.eval('(' + str + ')');
又比如調(diào)試時(shí)使用alert,很少有人使用window.alert;IE中獲取事件對(duì)象使用event,很少有人使用window.event。(Firefox中在某些情況下也支持event而不支持window.event。感興趣的同學(xué)看看這篇 獲取事件對(duì)象的全家)
但由于各個(gè)引擎實(shí)現(xiàn)差異,它們的區(qū)別還是有的。
var x = 5;
function fn(){
var x = 'jack';
eval('x=10;');
}
fn();
alert(x); // -->5
所有瀏覽器中輸出的都是5,說(shuō)明調(diào)用fn后eval修改的是fn內(nèi)的局部變量x,而非全局的x。即eval執(zhí)行的閉包環(huán)境是在fn內(nèi)。
修改下,把以上代碼的eval換成window.eval,測(cè)試后發(fā)現(xiàn)各個(gè)瀏覽器中的表現(xiàn)不一樣了。
IE6/7/8 : 仍然輸出5,即沒(méi)有修改全局變量x,修改的仍然是局部變量x。
IE9/Firefox/Safari/Chrome/Opera : 輸出10,修改的是全局變量x。
可以得出結(jié)論了
IE6/7/8中,eval和window.eval一樣,寫在自定義函數(shù)內(nèi)是局部閉包,否則是全局閉包。
IE9/Firefox/Safari/Chrome/Opera中,eval同以上IE6/7/8,window.eval即使寫在自定義函數(shù)內(nèi)使用的也是全局閉包。
此外:IE中的window.execScript總是在全局閉包下執(zhí)行,令人驚奇的是Chrome也支持該方法。呵,Chrome策略是標(biāo)準(zhǔn),IE一個(gè)不能少。
開發(fā)過(guò)程中似乎很少有人去加個(gè)額外的window,覺(jué)得多此一舉。比如Ajax過(guò)程中回調(diào)函數(shù)解析JSON格式字符串
復(fù)制代碼 代碼如下:
...
function callback(str){
var json = eval('(' + str + ')');
}
...
通常直接使用eval,而非var json = window.eval('(' + str + ')');
又比如調(diào)試時(shí)使用alert,很少有人使用window.alert;IE中獲取事件對(duì)象使用event,很少有人使用window.event。(Firefox中在某些情況下也支持event而不支持window.event。感興趣的同學(xué)看看這篇 獲取事件對(duì)象的全家)
但由于各個(gè)引擎實(shí)現(xiàn)差異,它們的區(qū)別還是有的。
復(fù)制代碼 代碼如下:
var x = 5;
function fn(){
var x = 'jack';
eval('x=10;');
}
fn();
alert(x); // -->5
所有瀏覽器中輸出的都是5,說(shuō)明調(diào)用fn后eval修改的是fn內(nèi)的局部變量x,而非全局的x。即eval執(zhí)行的閉包環(huán)境是在fn內(nèi)。
修改下,把以上代碼的eval換成window.eval,測(cè)試后發(fā)現(xiàn)各個(gè)瀏覽器中的表現(xiàn)不一樣了。
IE6/7/8 : 仍然輸出5,即沒(méi)有修改全局變量x,修改的仍然是局部變量x。
IE9/Firefox/Safari/Chrome/Opera : 輸出10,修改的是全局變量x。
可以得出結(jié)論了
IE6/7/8中,eval和window.eval一樣,寫在自定義函數(shù)內(nèi)是局部閉包,否則是全局閉包。
IE9/Firefox/Safari/Chrome/Opera中,eval同以上IE6/7/8,window.eval即使寫在自定義函數(shù)內(nèi)使用的也是全局閉包。
此外:IE中的window.execScript總是在全局閉包下執(zhí)行,令人驚奇的是Chrome也支持該方法。呵,Chrome策略是標(biāo)準(zhǔn),IE一個(gè)不能少。
相關(guān)文章
cnblogs csdn 代碼運(yùn)行框?qū)崿F(xiàn)代碼
大家用cnblogs,csdn博客發(fā)布技術(shù)文檔的時(shí)候,可以用下面的代碼實(shí)現(xiàn)運(yùn)行功能。當(dāng)然大家看了源碼就會(huì)發(fā)現(xiàn)其實(shí)方法還有很多。有更好的方法就發(fā)布一下啊。2009-11-11使用typescript類型實(shí)現(xiàn)ThreeSum
這篇文章主要介紹了使用typescript類型實(shí)現(xiàn)ThreeSum,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以一下,希望對(duì)你學(xué)習(xí)又是幫助2022-08-08JavaScript實(shí)現(xiàn)簡(jiǎn)單動(dòng)態(tài)表格
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單動(dòng)態(tài)表格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12Webpack4+Babel7+ES6兼容IE8的實(shí)現(xiàn)
這篇文章主要介紹了Webpack4+Babel7+ES6兼容IE8的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04JS簡(jiǎn)單實(shí)現(xiàn)查看文檔創(chuàng)建日期、修改日期和文檔大小的方法示例
這篇文章主要介紹了JS簡(jiǎn)單實(shí)現(xiàn)查看文檔創(chuàng)建日期、修改日期和文檔大小的方法,結(jié)合實(shí)例形式分析了JavaScript使用fileCreatedDate屬性、fileModifiedDate屬性、lastModified屬性和fileSize屬性相關(guān)操作技巧,需要的朋友可以參考下2018-04-04微信小程序 websocket 實(shí)現(xiàn)SpringMVC+Spring+Mybatis
這篇文章主要介紹了 微信小程序websocket實(shí)現(xiàn)SpringMVC+Spring+Mybatis的相關(guān)資料,這里提供實(shí)現(xiàn)思路及實(shí)現(xiàn)代碼,需要的朋友可以參考下2017-08-08