溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在Javascript中使用解構(gòu)賦值語(yǔ)法

發(fā)布時(shí)間:2021-04-02 14:28:17 來源:億速云 閱讀:181 作者:Leah 欄目:開發(fā)技術(shù)

本篇文章給大家分享的是有關(guān)如何在Javascript中使用解構(gòu)賦值語(yǔ)法,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

前言

首先在 ES6中引入的“解構(gòu)賦值語(yǔ)法”允許把數(shù)組和對(duì)象中的值插入到不同的變量中。雖然看上去可能很難,但實(shí)際上很容易學(xué)習(xí)和使用。

解構(gòu)賦值語(yǔ)法是一種 JS表達(dá)式。ES6 允許按照一定模式,從數(shù)組和對(duì)象中提取值,對(duì)變量進(jìn)行賦值,這被稱為解構(gòu)。通過解構(gòu)賦值, 可以將屬性/值從對(duì)象/數(shù)組中取出,賦值給其他變量。

在ES6解構(gòu)賦值出現(xiàn)之前,我們需要為變量賦值的時(shí)候,只能直接指定值。

比如:

let a = 1;
let b = 2;
let c = 3;
let d = 4;
let e = 5;

數(shù)組解構(gòu)非常簡(jiǎn)單。你所要做的就是為數(shù)組中的每個(gè)值聲明一個(gè)變量。你可以定義更少的變量,而不是數(shù)組中的索引(即,如果你只想解處理前幾個(gè)值),請(qǐng)?zhí)^某些索引或甚至使用 REST 模式將所有剩余的值放到新數(shù)組中。

const nums = [ 3, 6, 9, 12, 15 ];
const [
 k,    // k = 3
 l,    // l = 6
 ,    // Skip a value (12)
 ...n   // n = [12, 15]
] = nums;

對(duì)象解構(gòu)

對(duì)象解構(gòu)與數(shù)組解構(gòu)非常相似,主要區(qū)別是可以按名稱引用對(duì)象中的每個(gè)key,從而創(chuàng)建一個(gè)有相同名稱的變量。此外還可以將鍵解構(gòu)為新的變量名,只解構(gòu)所需的 key,然后用 rest 模式將剩余的 key 解構(gòu)為新對(duì)象。

const obj = { a: 1, b: 2, c: 3, d: 4 };
const {
 a,       // a = 1
 c: d,      // d = 3
 ...rest     // rest = { b: 2, d: 4 }
} = obj;

嵌套解構(gòu)

嵌套對(duì)象和數(shù)組可以通過相同的規(guī)則來進(jìn)行解構(gòu)。區(qū)別在于可以將嵌套 key 或值直接解構(gòu)為變量,而不必將父對(duì)象存儲(chǔ)在變量本身中。

const nested = { a: { b: 1, c: 2 }, d: [1, 2]};
const {
 a: {
  b: f,     // f = 1
  ...g     // g = { c: 2 }
 },
 ...h      // h = { d: [1, 2]}
} = nested;

高級(jí)解構(gòu)

由于數(shù)組的行為與對(duì)象相似,所以可以通過使用索引作為對(duì)象解構(gòu)分配中的 key,用解構(gòu)分配語(yǔ)法從數(shù)組中獲取特定值。用這種方法還可以得到數(shù)組的其他屬性(例如數(shù)組的 length)。最后,如果解構(gòu)后的值是 undefined,則還可以為解構(gòu)過程中的變量定義默認(rèn)值。

const arr = [ 5, 'b', 4, 'd', 'e', 'f', 2 ];
const {
 6: x,      // x = 2
 0: y,      // y = 5
 2: z,      // z = 4
 length: count, // count = 7
 name = 'array', // name = 'array' (not present in arr)
 ...restData   // restData = { '1': 'b', '3': 'd', '4': 'e', '5': 'f' }
} = arr;

以上就是如何在Javascript中使用解構(gòu)賦值語(yǔ)法,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI