ECMAScript6學習筆記-D1 let命令

@ (2017年7月11日) [馬克飛象 | Markdown格式]

ECMAScript 6:ECMAScript 6(以下簡稱ES6)是JavaScript語言的下一代標準厢破,正處在快速開發(fā)之中,大部分已經(jīng)完成了治拿,預計將在2015年6月正式發(fā)布摩泪。ES6的目標,是使得JavaScript語言可以用來編寫大型的復雜的應(yīng)用程序劫谅,成為企業(yè)級開發(fā)語言见坑。

  • ECMAScript和JavaScript的關(guān)系 :前者是后者的規(guī)格嚷掠,后者是前者的一種實現(xiàn)(另外的 ECMAScript 方言還有 Jscript 和 ActionScript)。日常場合鳄梅,這兩個詞是可以互換的叠国;

es6 babel轉(zhuǎn)碼器安裝配置

cfcb7e49b9a6d2d6d234d904c6da5a17.png

let命令

let命令: 聲明變量,用法類似于var戴尸,但let聲明的變量,只在let命令所在的代碼塊內(nèi)有效冤狡。

let和var

{
     let a = 10;
     var b = 1;
}
console.log(a); // ReferenceError: a is not defined.
console.log(b); // 1

let命令和for循環(huán)

**用let聲明的計數(shù)器i **只在for循環(huán)體內(nèi)有效孙蒙。

let arr = [1,2,3,4,5,6];
for(let i = 0; i < arr.length; i++){
    console.log(i);
}
console.log(i);//ReferenceError: i is not defined

使用var,最后輸出的是9

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

使用let悲雳,聲明的變量僅在塊級作用域內(nèi)有效挎峦,最后輸出的是6

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

let不會發(fā)生“變量提升”現(xiàn)象

代碼如下:

function do_something() {
       console.log(foo); // ReferenceError
       let foo = 2;
       console.log(foo);//2
}
do_something();

暫時性死區(qū)

只要塊級作用域內(nèi)存在let命令,它所聲明的變量就“綁定”(binding)這個區(qū)域合瓢,不再受外部的影響坦胶。

var tmp = 123;
if (true) {
  tmp = 'abc'; // ReferenceError
  let tmp;
}

注意:ES6明確規(guī)定,如果區(qū)塊中存在let和const命令晴楔,這個區(qū)塊對這些命令聲明的變量顿苇,從一開始就形成了封閉作用域。凡是在聲明之前就使用這些變量税弃,就會報錯纪岁。

總之,在代碼塊內(nèi)则果,使用let命令聲明變量之前幔翰,該變量都是不可用的。這在語法上西壮,稱為“暫時性死區(qū)”(temporal dead zone遗增,簡稱 TDZ)

if (true) {
  // TDZ開始
  tmp = 'abc'; // ReferenceError
  console.log(tmp); // ReferenceError

  let tmp; // TDZ結(jié)束
  console.log(tmp); // undefined

  tmp = 123;
  console.log(tmp); // 123
}

上面代碼中,在let命令聲明變量tmp之前款青,都屬于變量tmp的“死區(qū)”做修。
“暫時性死區(qū)”也意味著typeof不再是一個百分之百安全的操作。

typeof x; // ReferenceError
let x;
//變量x使用let命令聲明可都,所以在聲明之前缓待,都屬于x的“死區(qū)”,只要用到該變量就會報錯渠牲。因此旋炒,typeof運行時就會拋出一個ReferenceError。

//但是签杈,如果一個變量根本沒有被聲明瘫镇,使用typeof反而不會報錯鼎兽。
typeof undeclared_variable // "undefined"

有些“死區(qū)”比較隱蔽,不太容易發(fā)現(xiàn)铣除。

function bar(x = y, y = 2) {
  return [x, y];
}
bar();                         // 報錯:y is not defined
//正確的:
function bar(x = 2, y = x) {
  return [x, y];
}
bar(); // [2, 2]

//另外
var x = x;                    // 不報錯
let x = x;                     // 報錯 ReferenceError: x is not defined

ES6 規(guī)定暫時性死區(qū)和let谚咬、const語句不出現(xiàn)變量提升,主要是為了減少運行時錯誤尚粘,防止在變量聲明前就使用這個變量择卦,從而導致意料之外的行為。這樣的錯誤在 ES5 是很常見的郎嫁,現(xiàn)在有了這種規(guī)定秉继,避免此類錯誤就很容易了。
總之泽铛,暫時性死區(qū)的本質(zhì)就是尚辑,只要一進入當前作用域,所要使用的變量就已經(jīng)存在了盔腔,但是不可獲取杠茬,只有等到聲明變量的那一行代碼出現(xiàn),才可以獲取和使用該變量弛随。

let不允許在相同作用域內(nèi)瓢喉,重復聲明同一個變量

// 報錯
{
    let a = 10;
    var a = 1;
}
// 報錯
{
    let a = 10;
    let a = 1;
}
//報的錯是  Uncaught SyntaxError: Identifier 'a' has already been declared
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末昵观,一起剝皮案震驚了整個濱河市甘苍,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌陕截,老刑警劉巖盐杂,帶你破解...
    沈念sama閱讀 216,843評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件逗载,死亡現(xiàn)場離奇詭異,居然都是意外死亡链烈,警方通過查閱死者的電腦和手機厉斟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來强衡,“玉大人擦秽,你說我怎么就攤上這事′銮冢” “怎么了感挥?”我有些...
    開封第一講書人閱讀 163,187評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長越败。 經(jīng)常有香客問我触幼,道長,這世上最難降的妖魔是什么究飞? 我笑而不...
    開封第一講書人閱讀 58,264評論 1 292
  • 正文 為了忘掉前任置谦,我火速辦了婚禮堂鲤,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘媒峡。我一直安慰自己瘟栖,他們只是感情好,可當我...
    茶點故事閱讀 67,289評論 6 390
  • 文/花漫 我一把揭開白布谅阿。 她就那樣靜靜地躺著半哟,像睡著了一般。 火紅的嫁衣襯著肌膚如雪奔穿。 梳的紋絲不亂的頭發(fā)上镜沽,一...
    開封第一講書人閱讀 51,231評論 1 299
  • 那天,我揣著相機與錄音贱田,去河邊找鬼。 笑死嘴脾,一個胖子當著我的面吹牛男摧,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播译打,決...
    沈念sama閱讀 40,116評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼耗拓,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了奏司?” 一聲冷哼從身側(cè)響起乔询,我...
    開封第一講書人閱讀 38,945評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎韵洋,沒想到半個月后竿刁,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,367評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡搪缨,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,581評論 2 333
  • 正文 我和宋清朗相戀三年食拜,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片副编。...
    茶點故事閱讀 39,754評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡负甸,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出痹届,到底是詐尸還是另有隱情呻待,我是刑警寧澤,帶...
    沈念sama閱讀 35,458評論 5 344
  • 正文 年R本政府宣布队腐,位于F島的核電站蚕捉,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏香到。R本人自食惡果不足惜鱼冀,卻給世界環(huán)境...
    茶點故事閱讀 41,068評論 3 327
  • 文/蒙蒙 一报破、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧千绪,春花似錦充易、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至瑞妇,卻和暖如春稿静,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背辕狰。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評論 1 269
  • 我被黑心中介騙來泰國打工改备, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人蔓倍。 一個月前我還...
    沈念sama閱讀 47,797評論 2 369
  • 正文 我出身青樓悬钳,卻偏偏與公主長得像,于是被迫代替她去往敵國和親偶翅。 傳聞我的和親對象是個殘疾皇子默勾,可洞房花燭夜當晚...
    茶點故事閱讀 44,654評論 2 354

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