Closure
此篇介紹一些關於Closure(閉包)的觀念
參考資料:深入淺出了解JS閉包
Basic And Think:
當你看到一個Function 裡面
return另一個 Function,通常就是有用到閉包的概念。透過閉包,可以讓 Function 有
private變數。有點「為了解決不同函數,使用同一變數的問題」之概念。
Example:
Basic Closure(基本示範):
function House(){
var count =0; //函式內要用到的變數
function countAnimal(){ //真正要執行的函數
count ++;
console.log(count+'dogs');
}
return countAnimal //執行完後把這個函式回傳出來
}
const FunctionName = House(); //有點拆封的感覺,這時的AAA會等於內部真正執行函數
FunctionName(); // 1 dogs
//所以執行一次就會count++一次。而var count 只會做在 const AAA內行一次。 More const(就算多個Function 使用同一個House(),也不會污染變數):
House(),也不會污染變數):將參數帶入閉包中:
簡潔寫法:
範圍鏈:
內層 func 可以讀取外層的宣告變數,但外層的 func 讀不到內層宣告的變數。若是在自己層級找不到,就往外找,直到 Global為止。
Last updated
Was this helpful?