淺談ECMAScript6新特性之let、const
第一次寫博客有點(diǎn)緊張,如果說(shuō)的不對(duì)的地方,歡迎大家留言指正。咱們先來(lái)說(shuō)說(shuō)“ECMAScript”這到底是啥玩意兒?它和javascript的關(guān)系又是如何的?首先,在1996年11月的時(shí)候,javascript的創(chuàng)造者(網(wǎng)景公司Netscape)和sun公司聯(lián)合ECMA(歐洲計(jì)算機(jī)制造商協(xié)會(huì))對(duì)javascript進(jìn)行標(biāo)準(zhǔn)化,次年,ECMA發(fā)布262號(hào)標(biāo)準(zhǔn)文件文件(ECMA-262)的第一版,規(guī)定了瀏覽器腳本語(yǔ)言的標(biāo)準(zhǔn)(在這里提個(gè)問(wèn)題:為什么要標(biāo)準(zhǔn)化?),并將這種語(yǔ)言稱為ECMAScript,這個(gè)版本就是1.0版的。這個(gè)標(biāo)準(zhǔn)一開(kāi)始就是針對(duì)與javascript來(lái)制定的,但是沒(méi)有稱之為“javascript”,這其中有兩個(gè)原因,一是:商標(biāo);二是:想體現(xiàn)這門語(yǔ)言的規(guī)格制定者是ECMA,這樣有利于保證開(kāi)發(fā)性和中立性。所以,ECMAScript和javascript之間的關(guān)系就是,前者來(lái)制定規(guī)格,后者來(lái)實(shí)現(xiàn)(另外的ECMAScript的實(shí)現(xiàn)還有JScript和ActionScript)。一般的情況下,這兩個(gè)詞是可以互換的。
接下來(lái)來(lái)介紹一下es6中的新特性之“l(fā)et”。首先,這個(gè)玩意兒其實(shí)和var這個(gè)命令類似,都是用于聲明變量的,但是所聲明的變量只在let命令所在的代碼塊內(nèi)有效(這里涉及到塊級(jí)作用域的概念,然而這個(gè)概念也是es6中提出來(lái)的。在后面我再來(lái)講。PS:在其他編程語(yǔ)言中,早就有塊級(jí)了)
上面的兩張圖就反映出了let所聲明的變量只在let命令所在的代碼塊內(nèi)有效。下面來(lái)舉個(gè)例子:
發(fā)現(xiàn)區(qū)別了嗎?var聲明的變量它是全局范圍內(nèi)都有效的,每一次的循環(huán),新的i值都會(huì)覆蓋舊值,導(dǎo)致最后輸出的是最后一輪的i值(當(dāng)然,也可以利用閉包來(lái)解決這個(gè)問(wèn)題【第三張圖】)。如果使用的是let,聲明的變量?jī)H在塊級(jí)作用域內(nèi)有效,當(dāng)前的i只在本輪循環(huán)有效,所以每一次循環(huán)i其實(shí)都是一個(gè)新的變量。在期間我發(fā)現(xiàn)了一個(gè)更神奇的東西,請(qǐng)看下面一張圖:
注意:①、let不像var一樣會(huì)發(fā)生“變量提升”的現(xiàn)象,所以,使用之前,必須先聲明,不然就會(huì)報(bào)錯(cuò)。
②、暫時(shí)性死區(qū)(temporal dead zone,簡(jiǎn)稱TDZ),只要塊級(jí)作用域內(nèi)有l(wèi)et命令,它所聲明的變量就會(huì)綁定這個(gè)區(qū)域,不收外部的的影響。簡(jiǎn)單的來(lái)說(shuō),在代碼塊中,使用let命令聲明變量之前,變量都是不能用的。例子:
③、let不允許在同一個(gè)作用域內(nèi)重復(fù)聲明同一個(gè)變量。
好了,現(xiàn)在再來(lái)講一講上文提及到的一個(gè)東東:“塊級(jí)作用域”。在es5中只有“全局作用域”和“函數(shù)作用域”。這使得我在剛開(kāi)始學(xué)的時(shí)候一臉蒙蔽,其他語(yǔ)言都有塊級(jí)作用域(比如C語(yǔ)言),但js就沒(méi)有。幸好在es6中加入了“塊級(jí)作用域”的概念,let實(shí)際上為javascript新增了塊級(jí)作用域,有了塊級(jí)作用域,就可以避免變量泄露成全局變量,代碼快之間不會(huì)受到影響。另外,es6里還規(guī)定了:函數(shù)本身的作用域在其塊級(jí)作用域內(nèi)。注意!注意!注意!重要的事說(shuō)三遍:(如果是在嚴(yán)格模式下,函數(shù)只能在頂級(jí)作用域和函數(shù)內(nèi)部聲明,其他情況下【比如:if語(yǔ)句、循環(huán)語(yǔ)句下】就會(huì)報(bào)錯(cuò)) :
最后再來(lái)說(shuō)說(shuō)es6中的新特性之“const”,好吧,其他編程語(yǔ)言里早就有了,但是javascript在es6之前還是沒(méi)有~~。這個(gè)是用來(lái)聲明常量的,其表現(xiàn)為不可修改的,還有就是聲明的同時(shí)必須進(jìn)行賦值,否則就會(huì)報(bào)錯(cuò)。
注意:①、在作用域方面,它其實(shí)和let作用域相同:只在聲明所在的塊級(jí)作用域內(nèi)有效;
?、?、const命令聲明的常量同樣不存在“變量提升”,同樣存在“暫時(shí)性死區(qū)”,必須在聲明后才能使用。
?、?、const也不能重復(fù)聲明常量。
綜合例子:
?、堋?duì)于復(fù)合類型的變量,常量名不指向數(shù)據(jù),而是指向的是數(shù)據(jù)的指針地址,const命令只是保證了地址沒(méi)有變,但并不保證數(shù)據(jù)的不變,所以在使用const命令聲明常量為對(duì)象時(shí)要小心!!其實(shí)我們可以對(duì)其對(duì)象進(jìn)行“凍結(jié)”,使用Object.freeze()即可實(shí)現(xiàn)。
以上這篇淺談ECMAScript6新特性之let、const就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript學(xué)習(xí)歷程和心得小結(jié)
在過(guò)去,JavaScript只是被用來(lái)做一些簡(jiǎn)單的網(wǎng)頁(yè)效果,比如表單驗(yàn)證、浮動(dòng)廣告等,所以那時(shí)候JavaScript并沒(méi)有受到重視。2010-08-08javascript定義變量時(shí)加var與不加var的區(qū)別
這篇文章主要介紹了javascript 變量中 var 與不加var的區(qū)別,需要的朋友可以參考下2014-12-12javascript XMLHttpRequest對(duì)象全面剖析
通過(guò)不必把Web頁(yè)面寄送到服務(wù)器而實(shí)現(xiàn)數(shù)據(jù)傳送,XMLHttpRequest對(duì)象為客戶端與服務(wù)器之間提供了一種動(dòng)態(tài)的交互能力。2010-04-04JavaScript之?dāng)?shù)組(Array)詳解
這篇文章主要介紹了JavaScript之?dāng)?shù)組(Array)詳解,本文詳細(xì)講解了JavaScript數(shù)組的創(chuàng)建、檢測(cè)數(shù)組、轉(zhuǎn)化方法、棧方法、隊(duì)列方法、重排序方法、操作方法、位置方法等內(nèi)容,需要的朋友可以參考下2015-04-04Internet Explorer 11 瀏覽器介紹:別叫我IE
這篇文章主要介紹了Internet Explorer 11 瀏覽器介紹:別叫我IE,需要的朋友可以參考下2014-09-09Typescript中的as、問(wèn)號(hào)與感嘆號(hào)詳解
這篇文章主要介紹了Typescript中的as、問(wèn)號(hào)與感嘆號(hào)詳解,本文分別講述了這幾個(gè)關(guān)鍵字的含義作用以及實(shí)例,通過(guò)文字和代碼的描述,詳細(xì)的表達(dá).以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07談?wù)勱P(guān)于JavaScript 中的 MVC 模式
本文介紹了模型-視圖-控制器模式在 JavaScript 中的實(shí)現(xiàn),有需要的朋友可以參考一下2013-04-04JavaScript 學(xué)習(xí)筆記(九)call和apply方法
兩者實(shí)現(xiàn)的功能是完全一樣的,只是參數(shù)傳遞方式不一樣,call是將各個(gè)參數(shù)以逗號(hào)(,)隔開(kāi),而apply是將所有參數(shù)組成一個(gè)數(shù)組進(jìn)行傳遞。2010-01-01