摘要:當(dāng)冒號右側(cè)存在花括號時,表示目標(biāo)被嵌套在對象的更深一層中。在對象的嵌套解構(gòu)中同樣能為本地變量使用不同的名稱提取數(shù)組解構(gòu)結(jié)構(gòu)賦值基本忽略一些選項重新賦值默認(rèn)值數(shù)組解構(gòu)賦值同樣允許在數(shù)組任意位置指定默認(rèn)值。
主要知識點:對象解構(gòu)、數(shù)組解構(gòu)、混合解構(gòu)以及參數(shù)解構(gòu)
《深入理解ES6》筆記 目錄
對象解構(gòu) 對象解構(gòu)對象解構(gòu)簡單的例子
let node = { type: "Identifier", name: "foo" }; let { type, name } = node; console.log(type); // "Identifier" console.log(name); // "foo"解構(gòu)賦值
let node = { type: "Identifier", name: "foo" }, type = "Literal", name = 5; //使用解構(gòu)來分配不同的值 ({ type, name } = node); console.log(type); // "Identifier" console.log(name); // "foo"
在函數(shù)中使用解構(gòu)賦值
let node = { type: "Identifier", name: "foo" }, type = "Literal", name = 5; function outputInfo(value) { console.log(value === node); // true } outputInfo({ type, name } = node); console.log(type); // "Identifier" console.log(name); // "foo"默認(rèn)值
當(dāng)你使用解構(gòu)賦值語句時,如果所指定的本地變量在對象中沒有找到同名屬性,那么該變量會被賦值為 undefined 。
let node = { type: "Identifier", name: "foo" }; let { type, name, value } = node; console.log(type); // "Identifier" console.log(name); // "foo" console.log(value); // undefined
可以選擇性地定義一個默認(rèn)值,以便在指定屬性不存在時使用該值:
let node = { type: "Identifier", name: "foo" }; let { type, name, value = true } = node; console.log(type); // "Identifier" console.log(name); // "foo" console.log(value); // true賦值給不同的本地變量名
let node = { type: "Identifier", name: "foo" }; //讀取名為 type 的屬性,并把它的值存儲在變量 localType 上 let { type: localType, name: localName } = node; console.log(localType); // "Identifier" console.log(localName); // "foo"
也可以給變量別名添加默認(rèn)值,依然是在本地變量名稱后添加等號與默認(rèn)值,例如:
let node = { type: "Identifier" }; //該語法實際上與傳統(tǒng)對象字面量語法相反,傳統(tǒng)語法將名稱放在冒號左邊、值放在冒號右邊;而在本例中,則是名稱在右邊,需要進行值讀取的位置則被放在了左邊。 let { type: localType, name: localName = "bar" } = node; console.log(localType); // "Identifier" console.log(localName); // "bar"嵌套的對象解構(gòu)
使用類似于對象字面量的語法,可以深入到嵌套的對象結(jié)構(gòu)中去提取你想要的數(shù)據(jù):
let node = { type: "Identifier", name: "foo", loc: { start: { line: 1, column: 1 }, end: { line: 1, column: 4 } } }; //每當(dāng)有一個冒號在解構(gòu)模式中出現(xiàn),就意味著冒號之前的標(biāo)識符代表需要檢查的位置,而冒號右側(cè)則是賦值的目標(biāo)。當(dāng)冒號右側(cè)存在花括號時,表示目標(biāo)被嵌套在對象的更深一層中。 let { loc: { start }} = node; console.log(start.line); // 1 console.log(start.column); // 1
在對象的嵌套解構(gòu)中同樣能為本地變量使用不同的名稱:
let node = { type: "Identifier", name: "foo", loc: { start: { line: 1, column: 1 }, end: { line: 1, column: 4 } } }; // 提取 node.loc.start let { loc: { start: localStart }} = node; console.log(localStart.line); // 1 console.log(localStart.column); // 1數(shù)組解構(gòu) 結(jié)構(gòu)賦值
基本
let colors = [ "red", "green", "blue" ]; let [ firstColor, secondColor ] = colors; console.log(firstColor); // "red" console.log(secondColor); // "green"
忽略一些選項
let colors = [ "red", "green", "blue" ]; let [ , , thirdColor ] = colors; console.log(thirdColor); // "blue"
重新賦值
let colors = [ "red", "green", "blue" ], firstColor = "black", secondColor = "purple"; [ firstColor, secondColor ] = colors; console.log(firstColor); // "red" console.log(secondColor); // "green"默認(rèn)值
數(shù)組解構(gòu)賦值同樣允許在數(shù)組任意位置指定默認(rèn)值。當(dāng)指定位置的項不存在、或其值為undefined ,那么該默認(rèn)值就會被使用:
let colors = [ "red" ]; let [ firstColor, secondColor = "green" ] = colors; console.log(firstColor); // "red" console.log(secondColor); // "green"嵌套的解構(gòu)
在整個解構(gòu)模式中插入另一個數(shù)組模式,解構(gòu)操作就會下行到嵌套的數(shù)組中,就像這樣:
let colors = [ "red", [ "green", "lightgreen" ], "blue" ]; // 隨后 let [ firstColor, [ secondColor ] ] = colors; console.log(firstColor); // "red" console.log(secondColor); // "green"剩余項
數(shù)組解構(gòu)有個名為剩余項( rest items )的概念,它使用 ... 語法來將剩余的項目賦值給一個指定的變量:
三個點的解構(gòu)賦值必須放在所有解構(gòu)元素的最末尾,否則報錯。
let colors = [ "red", "green", "blue" ]; let [ firstColor, ...restColors ] = colors; console.log(firstColor); // "red" console.log(restColors.length); // 2 console.log(restColors[0]); // "green" console.log(restColors[1]); // "blue"
也可以進行數(shù)組的克隆操作:
/ 在 ES5 中克隆數(shù)組 var colors = [ "red", "green", "blue" ]; var clonedColors = colors.concat(); console.log(clonedColors); //"[red,green,blue]" // 在 ES6 中克隆數(shù)組 let colors = [ "red", "green", "blue" ]; let [ ...clonedColors ] = colors; console.log(clonedColors); //"[red,green,blue]"混合解構(gòu)
混合解構(gòu)指的是對象和數(shù)組混合起來,執(zhí)行解構(gòu)操作
let node = { type: "Identifier", name: "foo", loc: { start: { line: 1, column: 1 }, end: { line: 1, column: 4 } }, range: [0, 3] }; let { loc: { start }, range: [ startIndex ] } = node; console.log(start.line); // 1 console.log(start.column); // 1 console.log(startIndex); // 0參數(shù)解構(gòu)
原函數(shù)寫法:
// options 上的屬性表示附加參數(shù) function setCookie(name, value, options) { options = options || {}; let secure = options.secure, path = options.path, domain = options.domain, expires = options.expires; // 設(shè)置 cookie 的代碼 } // 第三個參數(shù)映射到 options setCookie("type", "js", { secure: true, expires: 60000 });
問題:無法僅通過查看函數(shù)定義就判斷出函數(shù)所期望的輸入,必須閱讀函數(shù)體的代碼。
重寫函數(shù):
function setCookie(name, value, { secure, path, domain, expires }) { // 設(shè)置 cookie 的代碼 } setCookie("type", "js", { secure: true, expires: 60000 });解構(gòu)的參數(shù)是必需的
參數(shù)解構(gòu)有一個怪異點:默認(rèn)情況下調(diào)用函數(shù)時未給參數(shù)解構(gòu)傳值會拋出錯誤:
// 出錯! setCookie("type", "js");
可以這樣寫避免錯誤:
function setCookie(name, value, { secure, path, domain, expires } = {}) { // ... }參數(shù)解構(gòu)的默認(rèn)值
function setCookie(name, value, { secure = false, path = "/", domain = "example.com", expires = new Date(Date.now() + 360000000) } = {} ) { // ... }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/108477.html
摘要:解構(gòu),一種黑魔法解構(gòu)是從對象中提取出更小元素的過程。賦值是對解構(gòu)出來的元素進行重新賦值。總結(jié)本章講解了對象解構(gòu)賦值和數(shù)組解構(gòu)賦值,以及對象和數(shù)組混合情況下的解構(gòu)賦值操作,最后一個知識點是解構(gòu)函數(shù)的參數(shù)。 解構(gòu),一種黑魔法 解構(gòu)是從對象中提取出更小元素的過程。賦值是對解構(gòu)出來的元素進行重新賦值。 下面的代碼你可能無法在瀏覽器上實時測試,推薦在babel官網(wǎng)在線測試代碼:在線測試ES6代碼...
摘要:最近買了深入理解的書籍來看,為什么學(xué)習(xí)這么久還要買這本書呢主要是看到核心團隊成員及的創(chuàng)造者為本書做了序,作為一個粉絲,還是挺看好這本書能給我?guī)硪粋€新的升華,而且本書的作者也非常厲害。 使用ES6開發(fā)已經(jīng)有1年多了,以前看的是阮一峰老師的ES6教程,也看過MDN文檔的ES6語法介紹。 最近買了《深入理解ES6》的書籍來看,為什么學(xué)習(xí)ES6這么久還要買這本書呢?主要是看到Daniel A...
摘要:數(shù)組的解構(gòu)賦值規(guī)定允許按照一定模式,從數(shù)組和對象中提取值對變量進行賦值,我們稱之為解構(gòu)。的規(guī)則是,只要有可能導(dǎo)致解構(gòu)的歧義,就不得使用圓括號。 數(shù)組的解構(gòu)賦值 ES6規(guī)定:允許按照一定模式,從數(shù)組和對象中提取值對變量進行賦值,我們稱之為解構(gòu)。以前賦值只能直接指定值 let a = 1; let b = 2; let c = 3; ES6允許以下這種做法 let [a, b, c] = ...
閱讀 2384·2023-04-25 19:27
閱讀 3494·2021-11-24 09:39
閱讀 3911·2021-10-08 10:17
閱讀 3401·2019-08-30 13:48
閱讀 1937·2019-08-29 12:26
閱讀 3127·2019-08-28 17:52
閱讀 3541·2019-08-26 14:01
閱讀 3539·2019-08-26 12:19