JavaScript中var與let的區(qū)別
前言:
var是JavaScript剛出現(xiàn)時(shí)就存在的變量聲明關(guān)鍵字,而let作為ES6才出現(xiàn)的變量聲明關(guān)鍵字,無(wú)疑兩者之間存在著很大的區(qū)別。那么具體有哪些區(qū)別呢?
1.作用域表現(xiàn)形式不同
var是函數(shù)作用域,let是塊級(jí)作用域
{
var monkey='熏悟空';
let pig='豬扒蓋';
}
console.log(monkey); //輸出undefined
console.log(pig); //報(bào)錯(cuò):pig is not deined
由上面代碼可見,let聲明的變量只在其所在的代碼塊有效,在代碼塊外部無(wú)效無(wú)法訪問(wèn),而var聲明的變量在該代碼塊所在的函數(shù)作用域內(nèi)都有效。
2.是否變量提升的區(qū)別
var聲明的變量會(huì)進(jìn)行變量提升,let聲明的變量不會(huì)進(jìn)行變量提升。
console.log(monkey); //undefined var monkey='熏悟空'; console.log(pig); //報(bào)錯(cuò):pig is not defined let pig='豬扒蓋';
同樣的邏輯,為什么var聲明的變量在它聲明之前調(diào)用會(huì)顯示未定義,而let聲明的變量在聲明之前調(diào)用會(huì)拋出異常呢,這就是兩者在變量提升上的區(qū)別,var聲明的變量存在變量提升,let聲明的變量不存在變量提升。
那么什么叫變量提升呢,我這里不做概念性的描述,我只說(shuō)我個(gè)人的理解,就是以上代碼實(shí)際上相當(dāng)于如下:
var monkey; console.log(monkey); //undefined monkey='熏悟空'; console.log(pig); //報(bào)錯(cuò):pig is not defined let pig='豬扒蓋';
看見區(qū)別了嗎,var聲明的變量會(huì)將聲明的變量提取到作用域的最上面進(jìn)行定義但不賦值,賦值操作還是在你的代碼處,所以你在調(diào)用var聲明的變量時(shí)就是一個(gè)已經(jīng)聲明但是并未定義值的變量,所以調(diào)用結(jié)果就是undefined,這就是所謂的變量提升。而let定義的變量不存在這種變量提升。
3.暫時(shí)性死區(qū)上的區(qū)別
暫時(shí)性死區(qū):如果在某一作用域內(nèi)let了一個(gè)變量,如果外部作用域中有相同名稱的變量,那么就算在作用域內(nèi)進(jìn)行了更改,也不會(huì)影響到外部作用域
具體表現(xiàn)如下:
for(var i=0;i<5;i++){
setTimeout(function(){
console.log(i)
},1000)
}
for(let i=0;i<5;i++){
setTimeout(function(){
console.log(i)
},1000)
}
請(qǐng)問(wèn)這兩處代碼的運(yùn)行結(jié)果分別是什么?
第一處代碼運(yùn)行完畢的結(jié)果是1s后順序打印5個(gè)5;第二處代碼運(yùn)行完畢的結(jié)果是1s后順序打印0,1,2,3,4。
請(qǐng)問(wèn)為什么會(huì)存在這種區(qū)別?
因?yàn)榈谝惶幋a的變量i由var關(guān)鍵字聲明,不存在關(guān)鍵性死區(qū),即你在1s后setTimeout中訪問(wèn)到的變量i是全局上下文中for循環(huán)運(yùn)行完畢之后的i,所以打印的結(jié)果全是5;
而第二處代碼的變量i由let關(guān)鍵字聲明,產(chǎn)生了關(guān)鍵性死區(qū),存在setTimeout中的i變量是你當(dāng)時(shí)存儲(chǔ)時(shí)的i的值,這個(gè)存儲(chǔ)區(qū)間的i不會(huì)因?yàn)橥饷嬗邢嗤膇變量且賦了不同的值而改變,他依舊是之前存儲(chǔ)進(jìn)去的值,這就是暫時(shí)性死區(qū)的表現(xiàn),也是為什么第二處代碼運(yùn)行完畢是順序打印0,1,2,3,4的原因。
4.在同一個(gè)上下文中var可以重復(fù)聲明,let不行
let monkey='熏悟空'; let monkey='逼馬吻'; //報(bào)錯(cuò):Identifier 'a' has already been declared var pig='豬扒蓋'; var pig='豬肛裂'; //正常訪問(wèn),變量pig的值被替換
到此這篇關(guān)于JavaScript中var與let的區(qū)別的文章就介紹到這了,更多相關(guān)JavaScript中var與let內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript檢測(cè)是否開啟了控制臺(tái)(F12調(diào)試工具)
通過(guò)js來(lái)檢測(cè)開發(fā)者工具是否打開,防止別人惡意調(diào)試我們的代碼,最近我發(fā)現(xiàn)還是有蠻多人去瀏覽那篇文章,所以這里再放出一段代碼,算是個(gè)升級(jí)版吧2020-10-10
Javascript實(shí)現(xiàn)div層漸隱效果的方法
這篇文章主要介紹了Javascript實(shí)現(xiàn)div層漸隱效果的方法,涉及javascript操作頁(yè)面元素與樣式變化的相關(guān)技巧,需要的朋友可以參考下2015-05-05
Bootstrap table 定制提示語(yǔ)的加載過(guò)程
bootstrap-table是在bootstrap-table的基礎(chǔ)上寫出來(lái)的,專門用于顯示數(shù)據(jù)的表格插件。這篇文章主要介紹了Bootstrap table 定制提示語(yǔ),需要的朋友可以參考下2017-02-02
JavaScript實(shí)現(xiàn)Date()日期格式化的3種常用方法
Date()日期對(duì)象是一個(gè)構(gòu)造函數(shù),必須使用new來(lái)調(diào)用創(chuàng)建我們的日期對(duì)象,下面這篇文章主要給大家介紹了關(guān)于JavaScript實(shí)現(xiàn)Date()日期格式化的3種常用方法,需要的朋友可以參考下2024-05-05
antDesign 自定義分頁(yè)樣式的實(shí)現(xiàn)代碼
這篇文章主要介紹了antDesign 自定義分頁(yè)樣式的實(shí)現(xiàn)代碼,這里用到了自定義指令,如果大家用不到可以按照自己的實(shí)際效果開發(fā),本文通過(guò)實(shí)例代碼給大家詳細(xì)講解,需要的朋友可以參考下2022-10-10

