欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ES6數(shù)組與對象的解構(gòu)賦值詳解

 更新時間:2019年06月14日 11:19:45   作者:學(xué)習(xí)筆記666  
這篇文章主要介紹了ES6數(shù)組與對象的解構(gòu)賦值,結(jié)合實例形式詳細分析了ES6中數(shù)組與對象的解構(gòu)賦值原理、用法及相關(guān)操作注意事項,需要的朋友可以參考下

本文實例講述了ES6數(shù)組與對象的解構(gòu)賦值。分享給大家供大家參考,具體如下:

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

基本用法

ES6允許按照一定的模式,從數(shù)組和對象中提取值,對變量進行賦值,這被稱之為解構(gòu)(Destructuring)

// 以前為變量賦值,只能直接指定值
var a = 1;
var b = 2;
var c = 3;
// ES6允許寫成這樣
var [a,b,c] = [1,2,3];

本質(zhì)上,這種寫法屬于“模式匹配”,只要等號兩邊的模式相同,左邊的變量就會被賦予對應(yīng)的值。

下面是一些使用嵌套數(shù)組進行解構(gòu)的例子:

let [foo,[[bar],baz]] = [1,[[2],3]];
foo // 1
bar // 2
baz // 3
let [,,third] = ["foo","bar","baz"];
third // "baz"
let [head,...tail] = [1,2,3,4];
head // 1
tail // [2,3,4]
let [x,y,...z] = ['a'];
x // "a"
y // undefined
z // []

默認值

解構(gòu)賦值允許制定默認值

var [foo = true] = [];
foo // true
[x,y='b'] = ['a'];
// x='a', y='b'

注意,ES6內(nèi)部使用嚴格相等運算符(===),判斷一個位置是否有值。

所以,如果一個數(shù)組成員不嚴格等于undefined,默認值是不會生效的。

var [x=1] = [undefined];
x //1
var [x=1] = [null];
x // null

如果默認值是一個表達式,那么這個表達式是惰性求值的,即只有在用到的時候,才會求值:

function f(){
 console.log('aaa');
}
let [x=f()] = [1];

上面的代碼中,因為x能取到值,所以函數(shù)f()根本不會執(zhí)行。上面的代碼其實等價于下面的代碼:

let x;
if([1][0] === undefined){
 x = f();
}else{
 x = [1][0];
}

默認值可以引用解構(gòu)賦值的其他變量,但該變量必須已經(jīng)聲明:

let [x=1,y=x] = [];
// x=1; y=1
let [x=1,y=x] = [2];
// x=2; y=2
let [x=1,y=x] = [1,2];
// x=1; y=2
let [x=y,y=1] = []; // ReferenceError

上面最后一個表達式,因為x用到默認值是y時,y還沒有聲明。

對象的解構(gòu)賦值

解構(gòu)不僅可以用于數(shù)組,還可以用于對象

var {foo,bar} = {foo:"aaa",bar:"bbb"};
foo // "aaa"
bar // "bbb"

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

var {bar,foo} = {foo:"aaa",bar:"bbb"};
foo // "aaa"
bar // "bbb"
var {baz} = {foo:"aaa",bar:"bbb"};
baz // undefined

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

var {foo:baz} = {foo:"aaa",bar:"bbb"};
baz // "aaa"
let obj = {first:"hello",last:"world"};
let {first:f,lats:l} = obj;
f // "hello"
l // "world"

對象的解構(gòu)賦值是內(nèi)部機制,是先找到同名屬性,然后再賦給對應(yīng)的變量。

真正被賦值的是后者,而不是前者。

var {foo:baz} = {foo:"aaa",bar:"bbb"};
baz // "aaa"
foo // error: foo is not defined

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

和數(shù)組一樣,解構(gòu)也可以用于嵌套解構(gòu)的對象

var obj = {
 p:["hello",{y:"world"}]
};
var {p:[x,{y}]} = obj;
x // "hello"
y // "world"

注意,這時p是模式,不是變量,因此不會被賦值。

對象的解構(gòu)也可以指定默認值:

var {x=3} = {};
x // 3
var {x,y=5} = {x:1};
x // 1
y // 5
var {x: y=3} = {x: 5};
y // 5

如果解構(gòu)失敗,變量的值等于undefined

var {foo} = {bar:"baz"};
foo // undefined

如果解構(gòu)模式是嵌套的對象,并且子對象所在的父屬性不存在,那么會報錯:

// 報錯
var {foo: {bar}} = {baz:"baz"};

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

var arr = [1,2,3];
var {0:first, [arr.length-1]:last} = arr;
first // 1
last // 3

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript查找算法技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

相關(guān)文章

  • Axios取消重復(fù)請求的方法實例詳解

    Axios取消重復(fù)請求的方法實例詳解

    在開發(fā)中,經(jīng)常會遇到接口重復(fù)請求導(dǎo)致的各種問題,這篇文章主要給大家介紹了關(guān)于Axios取消重復(fù)請求的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • JS原生帶小白點輪播圖實例講解

    JS原生帶小白點輪播圖實例講解

    下面小編就為大家?guī)硪黄狫S原生帶小白點輪播圖實例講解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • js 表格排序(編輯+拖拽+縮放)

    js 表格排序(編輯+拖拽+縮放)

    js 表格排序(編輯+拖拽+縮放)實現(xiàn)代碼,需要的朋友可以參考下。
    2010-05-05
  • JS實現(xiàn)猜拳游戲

    JS實現(xiàn)猜拳游戲

    這篇文章主要為大家詳細介紹了JS實現(xiàn)猜拳游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 原生JS實現(xiàn)瀑布流插件

    原生JS實現(xiàn)瀑布流插件

    本篇文章給大家詳細分析了一個原生JS實現(xiàn)瀑布流插件以及代碼相關(guān)講解,對此有興趣的讀者們參考學(xué)習(xí)下吧。
    2018-02-02
  • uni-app 支持多端第三方地圖定位的方法

    uni-app 支持多端第三方地圖定位的方法

    這篇文章主要介紹了uni-app 支持多端第三方地圖定位的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • js中事件的處理與瀏覽器對象示例介紹

    js中事件的處理與瀏覽器對象示例介紹

    本文為大家詳細介紹下js中關(guān)于簡單事件的處理與瀏覽器對象,下面有個不錯的示例,感興趣的朋友可以參考下
    2013-11-11
  • 一些很實用且必用的小腳本代碼

    一些很實用且必用的小腳本代碼

    一些很實用且必用的小腳本代碼...
    2006-08-08
  • js實現(xiàn)防止被iframe的方法

    js實現(xiàn)防止被iframe的方法

    這篇文章主要介紹了js實現(xiàn)防止被iframe的方法,實例分析了兩種比較常用的javascript防止頁面被iframe的技巧,非常簡單實用,需要的朋友可以參考下
    2015-07-07
  • js HTML5手機刮刮樂代碼

    js HTML5手機刮刮樂代碼

    這篇文章為大家詳細主要介紹了js HTML5手機刮刮樂代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10

最新評論