5 回答

TA貢獻1860條經驗 獲得超8個贊
這跟變量提升沒有關系,涉及到的知識是閉包和作用域。
閉包是一個函數,它能夠記住創建它的那個作用域,并且在那個作用域外調用時仍然能夠訪問那個作用域里的變量。
分析你的代碼:
var obj = {};
(function(obj){//作用域,命名為Scope
obj.m = function(){
//obj.m是一個聲明在Scope中函數,記住了當前作用域Scope。
console.log(ooo);
};
var ooo = {};//聲明在Scope中
})(obj);
obj.m();//當obj.m在Scope中調用時,根據閉包的定義,自然可以打印出 ooo {}
至于為什么不是打印undefined,是因為執行obj.m();時,Scope中的ooo已經完成了賦值操作。
另一方面,沒有報錯Uncaught ReferenceError:ooo is not defined;也是能證明obj.m確實持有對Scope中的ooo的引用,也就是形成了閉包。
我看了一下你的評論,覺得我們理解的閉包概念不一樣。我認為的閉包是obj.m,而你認為的閉包是(function(obj))(obj)這個IIFE。emmm,我覺得我是對的。

TA貢獻1821條經驗 獲得超6個贊
function foo() {
console.log(str);
}
var str = "aaaaa";
foo();
你說這段代碼輸出undefined還是aaaaa
只要調用的時候有值就行了

TA貢獻1803條經驗 獲得超3個贊

TA貢獻1820條經驗 獲得超9個贊
大哥,當你執行obj.m()這個方法時,我ooo早就賦值了好嗎。
除非這樣寫
var obj = {};
(function(obj){
obj.m = (function(){
console.log(ooo);
})();//這里改成自執行,這才是ooo還沒賦值, 你那個是在代碼末尾執行,我ooo已經賦了值了
var ooo = {};
})(obj);

TA貢獻1802條經驗 獲得超4個贊
var obj = {};//1
(function(obj){//2
obj.m = function(){//3
console.log(ooo);//6
};
var ooo = {};//4
})(obj);
obj.m();//5
添加回答
舉報