ES6筆記(Day1)

目標
  • 掌握如何定義變量
  • 掌握解構的內部機制
  • 掌握字符串模版

let關鍵字

可以限制變量作用域

  • Code 1:
{ 
    let a = 10; 
    var b = 1;
}
a // ReferenceError: a is not defined.
b // 1

適合使用使用在for循環中

  • Code 2:
//使用 var會出現 閉包的情況
var a = [];
for (var i = 0; i < 10; i++) { 
    a[i] = function () { 
        console.log(i); 
    };
}
a[6](); // 10
/*-------------------*/
//使用let自動解決閉包的問題
var a = [];
for (let i = 0; i < 10; i++) { 
    a[i] = function () { 
        console.log(i); 
    };
}
a[6](); // 6

不存在變量提升

  • Code 3:
console.log(foo); // 輸出undefined
console.log(bar); // 報錯ReferenceError
var foo = 2;
let bar = 2;

在代碼塊內,使用let命令聲明變量之前,該變量都是不可用的。這在語法上,稱為“暫時性死區”(temporal dead zone,簡稱TDZ)。

  • Code 4:
if (true) {  
    // TDZ開始 
    tmp = 'abc'; // ReferenceError 
    console.log(tmp); // ReferenceError 
    let tmp; // TDZ結束 
    console.log(tmp); // undefined 
    tmp = 123; 
    console.log(tmp); // 123
}

考一考,下面2個代碼片段的結果如何?

  • Code 5:
function bar(x = y, y = 2) {
    return [x, y];
}
bar();  // ??
  • Code 6:
function bar(x = 2, y = x) {
    return [x, y];
}
bar();  // ??

同一個作用域不能聲明多次

  • Code 7:
// 報錯
function () { 
    let a = 10; 
    var a = 1;
}

考一考

  • Code 8:
var tmp = new Date();
function f() { 
    console.log(tmp); 
    if (false) { 
        var tmp = "hello world"; 
    }
}
f();  // ??
  • Code 9:
var tmp = new Date();
function f() { 
    console.log(tmp); 
    if (false) { 
        tmp = "hello world"; 
    }
}
f();  // ??

可以舍棄匿名函數

  • Code 10:
// IIFE寫法
(function () { 
    var tmp = ...; 
    ...
}());
//
// 塊級作用域寫法
{ 
    let tmp = ...; 
    ...
}

為了兼容不同的es版本,請使用函數表達式

  • Code 11:
// 函數聲明語句
{
    let a = 'secret';
    function f() {
        return a;
    }
}
// 函數表達式
{
    let a = 'secret';
    let f = function () {
        return a;
    };
}

const 申明常量

對于復合類型的變量,變量名不指向數據,而是指向數據所在的地址。const
命令只是保證變量名指向的地址不變,并不保證該地址的數據不變

  • Code 12:
const foo = {};
foo.prop = 123;
foo.prop // 123
foo = {}; // TypeError: "foo" is read-only
  • Code 13:
const a = [];
a.push('Hello'); // 可執行
a.length = 0;    // 可執行
a = ['Dave'];    // 報錯

變量賦值

疑惑點:

  • 解構 ??

  • 解構允許使用默認值 ??

  • Generator函數 ??

  • yield ??

  • Generator函數,原生具有Iterator接口。解構賦值會依次從這個接口獲取值 ??

  • 默認表達式使用惰性求值 ??默認值是個函數 ?? 有值的話 默認函數會執行么??

  • 對象的解構賦值的內部機制,是先找到同名屬性,然后再賦給對應的變量。真正被賦值的是后者,而不是前者 ??

  • 解構賦值時,如果等號右邊是數值和布爾值,則會先轉為對象 ??

  • 哪些 不能使用圓括號的情況 ??

  • Code 14:

function f() {
    console.log('aaa');
}
let [x = f()] = [1];
  • Code 15:
let x;
if ([1][0] === undefined) {
    x = f();
} else {
    x = [1][0];
}
  • 解構的作用

交換變量的值

從函數返回多個值

函數參數的定義

提取JSON數據

函數參數的默認值

遍歷Map結構

輸入模塊的指定方法

字符串擴展

  • 模板字符串?

  • Code 16:

// 普通字符串
`In JavaScript '\\n' is a line-feed.`

// 多行字符串
`In JavaScript this is
 not legal.`

console.log(`string text line 1
string text line 2`);

// 字符串中嵌入變量
var name = "Bob", time = "today";
`Hello ${name}, how are you ${time}?`
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,646評論 6 533
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,595評論 3 418
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,560評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,035評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,814評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,224評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,301評論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,444評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,988評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,804評論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,998評論 1 370
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,544評論 5 360
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,237評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,665評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,927評論 1 287
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,706評論 3 393
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,993評論 2 374

推薦閱讀更多精彩內容