let 和const

1.let

用法類似var,但是聲明的變量只在代碼塊中有效

{    
      let a = 0;
      var b =1;
}
a //ReferenceError:a is not defined 
b //1

比如下面的案例:

var a = []
for(var i = 0;i<10;i++){
    a[i]=function(){
      console.log(i)
    }
}
a[9](); // 10
....
a[0](); // 10

會發(fā)現(xiàn),輸出的結(jié)果都是10,如果想輸出每一次的i的值,可以使用IIFE,或者最簡單的,把 var 改成 let

暫時性死區(qū)

只要塊級作用于存在let聲明的變量,那么這個變量就綁定了這個區(qū)域,不會在收到外部的影響

var a = 0;
if(true){
  a = 123; // referenceerror
  let a;
}
不允許重復(fù)聲明
function(){
  let a=0;
  let/var a =1; //報錯
}

2.塊級作用域

為什么需要塊級作用域

比如:

for(var i = 0;i<5;i++){
    ......
}
console.log(i); //5

變量i只想用來控制循環(huán),但是循環(huán)結(jié)束后,i沒消失,而泄露成了全局變量.

ES6的塊級作用域

比如:

function(){
  let a =1;
  if(1){
      let a = 2;
  }
console.log(a) // 1
}

兩個代碼塊都聲明了變量a,但是外層代碼塊不受內(nèi)層代碼塊的影響.

塊級作用域與函數(shù)聲明

ES5 規(guī)定,函數(shù)只能在頂層作用域和函數(shù)作用域之中聲明征唬,不能在塊級作用域聲明捌显。但是瀏覽器為了兼容以前的舊代碼,支持在會計作用于之中聲明函數(shù),不會報錯.

表現(xiàn):在瀏覽器的 ES6 環(huán)境中,塊級作用域內(nèi)聲明的函數(shù)总寒,行為類似于var聲明的變量扶歪。

const

const聲明一個只讀的常量,一旦聲明,值就不能改變

const p=3.14;
p// 3.14 
p= 1 ;TypeError: Assignment to constant variable.

因為值無法改變,所以在聲明的時候,就必須初始化,否則會報錯

const p;  //SyntaxError: Missing initializer in const declaration

作用域與let相同,且與let一樣不可重復(fù)聲明

const本質(zhì)

const本質(zhì)是保證const聲明的變量指向的地址不得改動.
比如:

const p = {}
p.a='a'
p= '123' //TypeError: "p" is read-only
other

letconst 都不存在變量提升,

頂層對象

頂層對象,瀏覽器中是window node中是global

window.a=1
a  //1

全局變量跟頂層對象的屬性是等價的.但在es6中 var 和function 聲明的依舊是頂層對象,但是let,const,class聲明的全局變量,不在屬于頂層對象.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市摄闸,隨后出現(xiàn)的幾起案子善镰,更是在濱河造成了極大的恐慌,老刑警劉巖年枕,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件炫欺,死亡現(xiàn)場離奇詭異,居然都是意外死亡熏兄,警方通過查閱死者的電腦和手機(jī)品洛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門树姨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人桥状,你說我怎么就攤上這事帽揪。” “怎么了辅斟?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵转晰,是天一觀的道長。 經(jīng)常有香客問我士飒,道長查邢,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任变汪,我火速辦了婚禮侠坎,結(jié)果婚禮上蚁趁,老公的妹妹穿的比我還像新娘裙盾。我一直安慰自己,他們只是感情好他嫡,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布番官。 她就那樣靜靜地躺著,像睡著了一般钢属。 火紅的嫁衣襯著肌膚如雪徘熔。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天淆党,我揣著相機(jī)與錄音酷师,去河邊找鬼。 笑死染乌,一個胖子當(dāng)著我的面吹牛山孔,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播荷憋,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼台颠,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了勒庄?” 一聲冷哼從身側(cè)響起串前,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎实蔽,沒想到半個月后荡碾,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡局装,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年坛吁,在試婚紗的時候發(fā)現(xiàn)自己被綠了漆腌。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡阶冈,死狀恐怖闷尿,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情女坑,我是刑警寧澤填具,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站匆骗,受9級特大地震影響劳景,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜碉就,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一盟广、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧瓮钥,春花似錦筋量、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至锈津,卻和暖如春呀酸,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背琼梆。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工性誉, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人茎杂。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓错览,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蛉顽。 傳聞我的和親對象是個殘疾皇子蝗砾,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評論 2 348

推薦閱讀更多精彩內(nèi)容