JavaScript ES6語法中let,const ,var 的區別
一、變量聲明的方式let / const
let / const 共同點
1.都是塊級作用域
2.在同一個作用域下,變量名不允許重復
3.他們聲明的全局變量並沒有掛在 window對象上
4.都沒有預編譯
let / const 不同點
1.let 聲明的變量值可以改變
2.const 聲明的變量值不能改變,必須聲明後立即賦值 (如:const a = 3.14;)
3.const 存引用數據類型時,內容可以發生改變(地址不能改變)
優先考慮使用const , 如果變量會發生改變,就使用let , 最後使用var
for循環中 var 和 let 的區別
var: 變量i是var命令聲明的,在全局范圍內都有效,所以全局隻有一個變量i。每一次循環,變量i的值都會發生改變 ,而循環內被賦給計時器內部的函數console.log(i) 裡面的i指向的就是全局的i。計時器是異步的,for循環結束後才執行。
for(var i = 1 ; i < 10 ; i++){ setTimeout(function () { console.log(i); // 輸出為 9 個 10 }) }
let:變量i是let聲明的,當前的i隻在本輪循環有效,所以每一次循環的i其實都是一個新的變量,所以最後輸出的是 1 2 3 4 5 6 7 8 9 10 。因為 JavaScript 引擎內部會記住上一輪循環的值,初始化本輪的變量 i 時,就在上一輪循環的基礎上進行計算。
for(let i = 0 ; i < 10 ; i++){ setTimeout(function () { console.log(i); // 0 1 2 3 4 5 6 7 8 9 }) }
總結
本篇文章就到這裡瞭,希望能夠給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!
推薦閱讀:
- JavaScript三大變量聲明詳析
- JS中箭頭函數與this的寫法和理解
- 淺談JavaScript宏任務和微任務執行順序
- 如何使JavaScript休眠或等待
- JavaScript的三座大山之單線程和異步