在2015年以前,JavaScript是沒有塊級做用域的,以後在ES6版本新增了塊級做用域,爲了更好的理解ES6這一新特性,咱們先提出這幾個問題:
1.什麼是塊級做用域?
2.爲何要添加塊級做用域?
3.怎麼使用塊級做用域?javascript
塊級做用域,就是指在只能在語句塊這個範圍中起做用,超出這個範圍則無效,其中語句塊,是指將多個語句放在一對大括號{}裏面,一般用於流程控制,好比if,for,while
等等。java
while (x < 10) { if(x>5){ x++; } }
這裏{if(x>5){x++;}}
是一個語句塊,{x++;}
也是一個語句塊,巧記:一對大括號就是一個語句塊,就表明一個做用域。閉包
ES6以前,變量只有全局做用域(也稱全局變量)和函數做用域(局部變量),因此會致使如下不合理的狀況:ide
var a = 0 (function() { console.log('函數內部調用全局的a:', a) //輸出:函數內部調用全局的a: 0 })() console.log('全局變量a:', a) //輸出;全局變量a: 0
var a = 0 ;(function() { console.log('a=', a) //輸出:a= undefined,按理說應該輸出a=0 if (false) { var a = 1 console.log(a) } })()
變量提高致使內層的 a 變量覆蓋了外層的 a 變量。
這就致使了若是你要在函數內部調用全局變量,那麼函數內聲明的局部變量就必定不能和全局變量同名。函數
(function() { console.log(a) //輸出:undefined if (true) { for (var a = 0; a < 10; a++) { var b = 0 console.log(a) //輸出:0~9 } } console.log('if以外a:', a) //輸出:if以外a: 10 console.log('if以外b:', b) //輸出:if以外b: 0 })()
在for循環中聲明的a,b變量,在函數結束前並不會被銷燬。
這樣就致使了一些沒必要要的內存消耗。
爲了不這兩個不合理的問題,塊級做用域就出現了。ui
使用變量命令 let
。code
(function() { if (true) { for (let a = 0; a < 10; a++) { console.log(a) //輸出:0~9 } } console.log('if以外a:', a) //報錯:ReferenceError: a is not defined })()
對於let
命令的變量:ip
let
命令代替閉包功能閉包實現:內存
var arr = []; for(var i = 0; i < 2; i++){ arr[i] = (function(i){ return function(){ console.log(i); }; }(i)); }; arr[1]();
let 實現:作用域
'use strict'; var arr = []; for(let i = 0; i < 2; i++){ arr[i] = function(){ console.log(i); }; }; arr[1]();
參考文章: