ES6:變量的解構(gòu)賦值

1、數(shù)組的解構(gòu)賦值

1.1、基本用法

ES6 允許按照一定模式,從數(shù)組和對(duì)象中提取值,對(duì)變量進(jìn)行賦值,這被稱為解構(gòu)(Destructuring)。
很久很久以前,我們?yōu)檫@里賦值,只能直接指定值。

let a = "x";
let b = "x";
let c = "b";

現(xiàn)在,用ES6,我們可以寫成:

let [a, b, c] = ["x", "x", "b"];

使用嵌套數(shù)組進(jìn)行結(jié)構(gòu)例子。

let [a, ...b] = [1, 2, 3, 4];
// 輸出
a // 1
b // [2, 3, 4]
解構(gòu)賦值
let [x, y, ...z] = ["x"];
x // "x"
y // undefined
z // []
解構(gòu)賦值

如果解構(gòu)不成功,變量的值就等于undefined

let [x] = [];
let [a, b] = [1];
解構(gòu)賦值

1.2、默認(rèn)值

解構(gòu)賦值允許指定默認(rèn)值。

let [a = true] = [];
let [x, y = "b"] = ["a", "diudiudiu"];
let [o, p = "hehe'] = ["haha", undefined];

注意,ES6 內(nèi)部使用嚴(yán)格相等運(yùn)算符(===),判斷一個(gè)位置是否有值。所以,如果一個(gè)數(shù)組成員不嚴(yán)格等于undefined,默認(rèn)值是不會(huì)生效的。

解構(gòu)賦值

2、對(duì)象的解構(gòu)賦值

let {a, b} = {a: "x", b: "y"};

對(duì)象的解構(gòu)與數(shù)組有一個(gè)重要的不同。數(shù)組的元素是按次序排列的,變量的取值由它的位置決定;而對(duì)象的屬性沒(méi)有次序,變量必須與屬性同名,才能取到正確的值。


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

如果變量名與屬性名不一致,必須寫成下面這樣。

let {a: c} = {a: "x", b: "y"};
c // x

let o = {first: "x", last: "b"};
let {first: f, last: l} = o;
對(duì)象解構(gòu)賦值

這實(shí)際上說(shuō)明,對(duì)象的解構(gòu)賦值是下面形式的簡(jiǎn)寫。

let { foo: foo, bar: bar } = { foo: "x", bar: "b" };

也就是說(shuō),對(duì)象的解構(gòu)賦值的內(nèi)部機(jī)制,是先找到同名屬性,然后再賦給對(duì)應(yīng)的變量。真正被賦值的是后者,而不是前者。

let {a: c} = {a: "x", b: "y"};

上面代碼中,a是匹配的模式,c才是變量。真正被賦值的是變量c,而不是模式a。

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

對(duì)象的解構(gòu)也可以指定默認(rèn)值。

let {a: b = 1} = {a: 0};
let {x: y = 3} = {x: 5};
對(duì)象解構(gòu)賦值

默認(rèn)值生效的條件是,對(duì)象的屬性值嚴(yán)格等于undefined。
如果解構(gòu)不成功,變量的值就等于undefined

let {a} = {b: "c"};
a // undefined

由于數(shù)組本質(zhì)是特殊的對(duì)象,因此可以對(duì)數(shù)組進(jìn)行對(duì)象屬性的解構(gòu)。

let arr = [1, 2, 3];
let {0: first, [arr.length - 1]: last} = arr;
first // 1
last // 3
對(duì)象解構(gòu)賦值

數(shù)組arr0鍵對(duì)應(yīng)的值是1,[arr.length - 1]就是2鍵,對(duì)應(yīng)的值是3。

3、字符串的解構(gòu)賦值

字符串也可以解構(gòu)賦值。這是因?yàn)榇藭r(shí),字符串被轉(zhuǎn)換成了一個(gè)類似數(shù)組的對(duì)象。

let [a, b, c] = "xxb";
字符串解構(gòu)賦值

類似數(shù)組的對(duì)象都有一個(gè)length屬性,因此還可以對(duì)這個(gè)屬性解構(gòu)賦值。

let {length: len} = "xxb666";
字符串解構(gòu)賦值

————
前端·小b
紙上學(xué)來(lái)終覺(jué)淺,絕知此事要躬行

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1.數(shù)組的解構(gòu)賦值 2.對(duì)象的解構(gòu)賦值 3.字符串的解構(gòu)賦值 4.數(shù)值和布爾值的解構(gòu)賦值 5.函數(shù)參數(shù)的解構(gòu)賦值 ...
    卞卞村長(zhǎng)L閱讀 952評(píng)論 0 0
  • 1、數(shù)組的解構(gòu)賦值 1.1、基本用法 ES6 允許按照一定模式,從數(shù)組和對(duì)象中提取值,對(duì)變量進(jìn)行賦值,這被稱為解構(gòu)...
    開(kāi)車去環(huán)游世界閱讀 177評(píng)論 0 0
  • 基本概念 只要某種數(shù)據(jù)結(jié)構(gòu)具有Iterator接口都可以采用解構(gòu)賦值和for of循環(huán) 如:1數(shù)組(有序)2對(duì)象(...
    coolheadedY閱讀 296評(píng)論 0 0
  • 針對(duì)ES6的變量賦值的有六種方式 默認(rèn)數(shù)組對(duì)象字符串?dāng)?shù)值與布爾值函數(shù) 1,解構(gòu)賦值允許指定默認(rèn)值。 2,數(shù)組的解構(gòu)...
    sponing閱讀 240評(píng)論 0 1
  • 當(dāng)你在努力成長(zhǎng)時(shí),如果有其他人嘲笑你,你完全可以無(wú)視他們的嘲弄。 原因很簡(jiǎn)單: 他們并不知道自己在嘲笑什么。 真正...
    寶中的寶閱讀 706評(píng)論 0 0

友情鏈接更多精彩內(nèi)容