国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

eval與window.eval的差別分析

2019-11-20 23:53:52
字體:
來源:轉載
供稿:網友
它們之間有區別嗎?

開發過程中似乎很少有人去加個額外的window,覺得多此一舉。比如Ajax過程中回調函數解析JSON格式字符串
復制代碼 代碼如下:

...
function callback(str){
var json = eval('(' + str + ')');
}
...

通常直接使用eval,而非var json = window.eval('(' + str + ')');
又比如調試時使用alert,很少有人使用window.alert;IE中獲取事件對象使用event,很少有人使用window.event。(Firefox中在某些情況下也支持event而不支持window.event。感興趣的同學看看這篇 獲取事件對象的全家)

但由于各個引擎實現差異,它們的區別還是有的。
復制代碼 代碼如下:

var x = 5;
function fn(){
var x = 'jack';
eval('x=10;');
}
fn();
alert(x); // -->5

所有瀏覽器中輸出的都是5,說明調用fn后eval修改的是fn內的局部變量x,而非全局的x。即eval執行的閉包環境是在fn內。

修改下,把以上代碼的eval換成window.eval,測試后發現各個瀏覽器中的表現不一樣了。

IE6/7/8 : 仍然輸出5,即沒有修改全局變量x,修改的仍然是局部變量x。
IE9/Firefox/Safari/Chrome/Opera : 輸出10,修改的是全局變量x。

可以得出結論了
IE6/7/8中,eval和window.eval一樣,寫在自定義函數內是局部閉包,否則是全局閉包。
IE9/Firefox/Safari/Chrome/Opera中,eval同以上IE6/7/8,window.eval即使寫在自定義函數內使用的也是全局閉包。

此外:IE中的window.execScript總是在全局閉包下執行,令人驚奇的是Chrome也支持該方法。呵,Chrome策略是標準,IE一個不能少。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 湾仔区| 湄潭县| 旬邑县| 开封县| 香格里拉县| 额敏县| 嘉义市| 滁州市| 万盛区| 阿鲁科尔沁旗| 文登市| 鹤岗市| 双桥区| 青阳县| 淳安县| 章丘市| 芦山县| 库伦旗| 滁州市| 呼伦贝尔市| 乐安县| 长兴县| SHOW| 萨嘎县| 岢岚县| 汉沽区| 当阳市| 体育| 农安县| 襄垣县| 米林县| 专栏| 晋州市| 赣榆县| 文安县| 康定县| 汉川市| 拜城县| 郴州市| 原阳县| 仁化县|