真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ES6教程:let和const命令的用法

ES6中新增了let和const命令,分別用于聲明變量和常量。

創(chuàng)新互聯(lián)公司是一家專業(yè)提供城子河企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、H5建站、小程序制作等業(yè)務(wù)。10年已為城子河眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。

1. 使用let命令取代var命令

在ES6之前的版本中,使用var聲明變量,在ES6中新增了let來聲明變量。let完全可以取代var,因?yàn)槎叩恼Z義相同,而且let沒有“副作用”。

我們先來看一下let命令有哪些特點(diǎn):

  1. 不存在變量提升:變量只有在聲明之后才能使用;
  2. 不允許重復(fù)聲明:在相同的作用域下,一個(gè)變量名只能使用一次,不能重復(fù)聲明;
  3. 具有塊級(jí)作用域:在代碼塊中聲明的變量,只對(duì)當(dāng)前代碼塊和其內(nèi)部嵌套代碼塊有效,如果嵌套代碼塊中聲明了同名變量時(shí),則對(duì)該嵌套代碼塊無效;
  4. 存在暫時(shí)性死區(qū):當(dāng)全局變量與代碼塊中變量同名時(shí),代碼塊中的變量就有了塊級(jí)作用域,其變量聲明前不能使用。

JavaScript是弱類型的編程語言,在ES6之前使用var關(guān)鍵字聲明變量,會(huì)發(fā)生變量提升的現(xiàn)象。簡(jiǎn)單來說,就是在聲明變量之前就對(duì)該變量進(jìn)行調(diào)用,程序不會(huì)報(bào)錯(cuò),而且打印出來的值為undefined。如果是有Java或C++編程經(jīng)驗(yàn)的小伙伴,肯定對(duì)這種現(xiàn)象是無法忍受的。我們用一段代碼來演示一下這種現(xiàn)象:

function test(){
    console.log(i);
    var i = 1;
}
test();

運(yùn)行結(jié)果:

undefined

上面代碼中,變量i是使用var命令聲明的,我們?cè)谧兞柯暶髦霸诳刂婆_(tái)打印i,雖然此時(shí)變量i還沒有聲明,但是該變量已經(jīng)存在了,只不過是沒有值,所以會(huì)輸出undefined

如果是同樣的代碼,把var替換成let來聲明,其他代碼不變,程序運(yùn)行后的結(jié)果為:

ES6教程:let和const命令的用法

當(dāng)變量使用let聲明時(shí),不會(huì)發(fā)生變量提升,這就說明在變量聲明之前,變量i是不存在的,要打印一個(gè)不存在的變量,就會(huì)拋出上面的錯(cuò)誤。

在ES5 中有兩個(gè)作用域,分別是全局作用域和函數(shù)作用域,到了ES6就新增了一個(gè)塊級(jí)作用域。如果沒有塊級(jí)作用域的話,在處理業(yè)務(wù)場(chǎng)景時(shí)會(huì)帶來很多不便,比如內(nèi)層變量覆蓋外層變量,再或者是使用for循環(huán)時(shí),循環(huán)中迭代的變量泄露為全局變量等等。

ES6中的let命令為JavaScript新增了塊級(jí)作用域,我們看下面的代碼:

function test() {
    let i = 1;
    if(true){
        let i = 2;
    }
    console.log(i);
}
test();

運(yùn)行結(jié)果為:

1

test()函數(shù)代碼塊中,對(duì)變量i做了兩次聲明,按照var命令聲明變量的邏輯,結(jié)果應(yīng)該是2,但是使用let命令聲明的變量,在該變量的代碼塊中,不受內(nèi)層代碼塊的影響。無論有多少層級(jí)的代碼塊,其每一層都有一個(gè)單獨(dú)的作用域。在內(nèi)層作用域中可以定義外層作用域的同名變量,但變量的值不受外層作用域變量的影響。

如果理解了let命令的塊級(jí)作用域的話,那么再來理解暫時(shí)性死區(qū),就輕松多了。我們對(duì)上面那段代碼稍加改造,演示暫時(shí)性死區(qū):

function test() {
    let i = 1;
    if(true){
        console.log(i);
        let i = 2;
    }
    console.log(i);
}
test();

運(yùn)行結(jié)果為:

ES6教程:let和const命令的用法

由于各層級(jí)代碼塊都有自己?jiǎn)为?dú)的作用域,內(nèi)層作用域不受外層的影響,所以當(dāng)我們?cè)?code>if()語句中再次聲明變量i時(shí),該作用域下的變量是獨(dú)立存在的,在未聲明之前就調(diào)用該變量,就會(huì)出現(xiàn)我們前面說過的“變量提升”的概念,let命令是不存在變量提升的,所以就會(huì)拋出上面這種錯(cuò)誤。

2. 使用const命令聲明常量

const命令的用法和let類似,使用const命令聲明的是一個(gè)只讀常量,一旦聲明,常量的值就不能改變。const聲明的變量值不能改變,這就意味著,變量一旦聲明后,就必須馬上給其賦初始化值。

但是在letconst之間,我建議優(yōu)先使用const,const相比let而言,有幾個(gè)優(yōu)點(diǎn):

一是const從語義上就表示常量,那就可以提醒協(xié)同開發(fā)的其他人員,這個(gè)變量的值不能被修改,防止誤操作修改變量的值導(dǎo)致程序出錯(cuò);

二是const比較符合函數(shù)式的編程思想,運(yùn)算不改變值,只是新建值;

三是JavaScript編譯器會(huì)對(duì)const進(jìn)行優(yōu)化,如果const使用頻率比較高的話,有利于提高程序的運(yùn)行效率,這取決于letconst在底層編譯器內(nèi)部的處理差異。

如果從長(zhǎng)遠(yuǎn)的角度看,JavaScript有可能會(huì)實(shí)現(xiàn)多線程編程,考慮到線程安全,let命令聲明的變量只能在單線程中使用,不能用于多線程的數(shù)據(jù)共享。


當(dāng)前文章:ES6教程:let和const命令的用法
URL網(wǎng)址:http://weahome.cn/article/gogche.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部