javascript - ES6中函數(shù)參數(shù)默認值為函數(shù)的問題?
問題描述
我對函數(shù)參數(shù)默認值為函數(shù)的情況有許多困惑比如
let foo = ’outer’;function bar(func = x => foo) { let foo = ’inner’; console.log(func()); }bar(); //outer
根據(jù)阮一峰的es6入門,我知道函數(shù)參數(shù)是默認值的話,會先有個塊級作用域包裹參數(shù),初始化結(jié)束后塊級作用域消失
一旦設(shè)置了參數(shù)的默認值,函數(shù)進行聲明初始化時,參數(shù)會形成一個單獨的作用域(context)。等到初始化結(jié)束,這個作用域就會消失。這種語法行為,在不設(shè)置參數(shù)默認值時,是不會出現(xiàn)的。
如果默認值是普通變量我能理解,但還是不懂為什么這里輸出的是outer而不是inner
問題解答
回答1:一句話:函數(shù)的閉包在定義時形成,而非運行時。
回答2:把語法糖徹底展開,應(yīng)該能看清楚點
let foo = ’outer’;function fk_compiler() { return foo;}function bar(func) { if (func === undefined) { func = fk_compiler; } let foo = ’inner’; console.log(func());}bar();
你看,fk_compiler里是不是只能返回外部作用域下的foo?
回答3:js是詞法作用域,foo值取函數(shù)定義時的值而不是執(zhí)行時的值。
回答4:基于回復(fù)者的代碼:
let foo = ’outer’;function fk_compiler() { return foo;}function bar(func) { if (func === undefined) { func = fk_compiler; } let foo = ’inner’; console.log(func());}bar();
js采取的是詞法作用域,所以,無論函數(shù)在哪里被調(diào)用,或者以任何形式被調(diào)用,其詞法作用域只由其被聲明時的位置決定。
fk_compiler被聲明的作用域在全局,所以,它會去訪問全局作用域中的foo。答案也就出來了。
類似代碼:
function foo(){ console.log(this.a);}(function init(){ var a = ’inner’;//此處改為 window.a = ’global’;再試試 foo();})();
相關(guān)文章:
1. docker gitlab 如何git clone?2. 關(guān)于docker下的nginx壓力測試3. 在windows下安裝docker Toolbox 啟動Docker Quickstart Terminal 失敗!4. angular.js使用$resource服務(wù)把數(shù)據(jù)存入mongodb的問題。5. docker鏡像push報錯6. PC 手機兼容的 編輯器7. angular.js - angularJs ngRoute怎么在路由傳遞空字符串及用ng-switch取得8. docker不顯示端口映射呢?9. docker-compose中volumes的問題10. mysql - 用PHPEXCEL將excel文件導(dǎo)入數(shù)據(jù)庫數(shù)據(jù)5000+條,本地數(shù)據(jù)庫正常,線上只導(dǎo)入15條,沒有報錯,哪里的問題?
