国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

深入理解ES6筆記(五)解構(gòu):使訪問數(shù)據(jù)更便捷

_DangJin / 3538人閱讀

摘要:當(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

相關(guān)文章

  • 深入理解ES6筆記——解構(gòu)使數(shù)據(jù)訪問便捷(5)

    摘要:解構(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代碼...

    Drinkey 評論0 收藏0
  • 深入理解ES6筆記——導(dǎo)讀

    摘要:最近買了深入理解的書籍來看,為什么學(xué)習(xí)這么久還要買這本書呢主要是看到核心團隊成員及的創(chuàng)造者為本書做了序,作為一個粉絲,還是挺看好這本書能給我?guī)硪粋€新的升華,而且本書的作者也非常厲害。 使用ES6開發(fā)已經(jīng)有1年多了,以前看的是阮一峰老師的ES6教程,也看過MDN文檔的ES6語法介紹。 最近買了《深入理解ES6》的書籍來看,為什么學(xué)習(xí)ES6這么久還要買這本書呢?主要是看到Daniel A...

    Godtoy 評論0 收藏0
  • ES6學(xué)習(xí)之 -- 解構(gòu)使數(shù)據(jù)訪問便捷

    摘要:數(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] = ...

    mrcode 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<