JavaScript?ES6語法中l(wèi)et,const?,var?的區(qū)別
一、變量聲明的方式let / const
let / const 共同點1.都是塊級作用域
2.在同一個作用域下,變量名不允許重復
3.他們聲明的全局變量并沒有掛在 window對象上
4.都沒有預編譯
let / const 不同點1.let 聲明的變量值可以改變
2.const 聲明的變量值不能改變,必須聲明后立即賦值 (如:const a = 3.14;)
3.const 存引用數(shù)據(jù)類型時,內容可以發(fā)生改變(地址不能改變)
優(yōu)先考慮使用const , 如果變量會發(fā)生改變,就使用let , 最后使用var
for循環(huán)中 var 和 let 的區(qū)別
var: 變量i是var命令聲明的,在全局范圍內都有效,所以全局只有一個變量i。每一次循環(huán),變量i的值都會發(fā)生改變 ,而循環(huán)內被賦給計時器內部的函數(shù)console.log(i) 里面的i指向的就是全局的i。計時器是異步的,for循環(huán)結束后才執(zhí)行。
for(var i = 1 ; i < 10 ; i++){ setTimeout(function () { console.log(i); // 輸出為 9 個 10 }) }
let:變量i是let聲明的,當前的i只在本輪循環(huán)有效,所以每一次循環(huán)的i其實都是一個新的變量,所以最后輸出的是 1 2 3 4 5 6 7 8 9 10 。因為 JavaScript 引擎內部會記住上一輪循環(huán)的值,初始化本輪的變量 i 時,就在上一輪循環(huán)的基礎上進行計算。
for(let i = 0 ; i < 10 ; i++){ setTimeout(function () { console.log(i); // 0 1 2 3 4 5 6 7 8 9 }) }
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!
相關文章
微信小程序 循環(huán)及嵌套循環(huán)的使用總結
這篇文章主要介紹了微信小程序 循環(huán)及嵌套循環(huán)的使用總結的相關資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-09-09詳解JavaScript實現(xiàn)簡單的詞法分析器示例
這篇文章主要為大家介紹了詳解JavaScript實現(xiàn)簡單的詞法分析器示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03微信小程序promsie.all和promise順序執(zhí)行
這篇文章主要介紹了微信小程序promsie.all和promise順序執(zhí)行的相關資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-10-10