這里為什么會報錯,bindEvent里的box1不是會沿著作用域鏈往上搜索嗎?
作用域的問題
蝴蝶不菲
2018-11-23 15:14:33
TA貢獻1845條經驗 獲得超8個贊
JS作用域基本都是詞法(靜態)作用域,也就定義的時候就確定了能訪問到的變量。(this是動態作用域)
box1在init()這個函數作用域(詞法作用域的一種)內定義,而bindEvent不在init內定義,所以他們的作用域鏈不同。
你可以改成這樣:
function init() {
const box1 = new Box(); // box1在init的作用域
function bindEvent() { // bindEvent在init的作用域
box1; // 不在bindEvent里定義,去作用鏈上的init的作用域里找,找到了
}
bindEvent();
}
或者這樣:
var box1;
function bindEvent() {
box1; // ok
}
function init() {
box1 = new Box();
bindEvent();
}
或者直接把box傳給bindEvent()。
舉報