亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

ES6數組與對象的解構賦值詳解

2019-11-19 11:20:47
字體:
來源:轉載
供稿:網友

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

數組的解構賦值

基本用法

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

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

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

下面是一些使用嵌套數組進行解構的例子:

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

默認值

解構賦值允許制定默認值

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

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

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

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

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

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

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

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

默認值可以引用解構賦值的其他變量,但該變量必須已經聲明:

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

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

對象的解構賦值

解構不僅可以用于數組,還可以用于對象

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

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

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"

對象的解構賦值是內部機制,是先找到同名屬性,然后再賦給對應的變量。

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

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

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

和數組一樣,解構也可以用于嵌套解構的對象

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

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

對象的解構也可以指定默認值:

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

如果解構失敗,變量的值等于undefined

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

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

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

由于數組本質是特殊的對象,因此可以對數組進行對象屬性的解構:

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

更多關于JavaScript相關內容可查看本站專題:《javascript面向對象入門教程》、《JavaScript查找算法技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人免费观看49www在线观看| 欧美日韩裸体免费视频| 欧美孕妇孕交黑巨大网站| 国产精品视频一区二区高潮| 日本最新高清不卡中文字幕| 日韩国产精品亚洲а∨天堂免| 97视频在线免费观看| 亚洲欧美国产一本综合首页| 欧美又大又粗又长| 成人综合网网址| 亚洲第一天堂无码专区| 欧美亚洲国产日韩2020| 日韩在线视频网站| 日韩av影院在线观看| 在线观看不卡av| 国产精品欧美久久久| 国产精品电影网站| 欧美日韩亚洲国产一区| 欧美日韩xxxxx| 国产精品视频成人| 91超碰caoporn97人人| 精品国产一区av| 91成人国产在线观看| 91热福利电影| 久久亚洲欧美日韩精品专区| 91av在线免费观看视频| 国产成人拍精品视频午夜网站| 国产日韩欧美黄色| 国产成人综合一区二区三区| 午夜欧美大片免费观看| 亚洲天堂av在线免费观看| 亚洲欧洲第一视频| 亚洲精品日韩激情在线电影| 国产精品白丝av嫩草影院| 国产成人久久精品| 69视频在线播放| 久久99精品久久久久久噜噜| 夜夜躁日日躁狠狠久久88av| 在线观看久久av| 亚洲成年网站在线观看| 日韩在线精品视频| 少妇高潮久久久久久潘金莲| 欧美亚洲成人xxx| 最近更新的2019中文字幕| 国产在线观看91精品一区| 亚洲成人激情小说| 亚洲aⅴ日韩av电影在线观看| 欧美成人免费观看| 午夜剧场成人观在线视频免费观看| 日韩电影中文字幕在线观看| 亚洲精品第一国产综合精品| 一区二区欧美亚洲| 国产大片精品免费永久看nba| 国产一区二区三区精品久久久| 亚洲美女又黄又爽在线观看| 久久精品美女视频网站| 欧美成人全部免费| 欧美日韩在线观看视频| 久久香蕉国产线看观看av| 欧美日韩精品在线| 一区二区欧美日韩视频| 日本久久91av| 热久久这里只有| 在线看国产精品| 久久91亚洲精品中文字幕| 亚洲香蕉成人av网站在线观看| 日韩精品中文字| 欧美另类极品videosbestfree| 欧美精品情趣视频| 国产精选久久久久久| 国产精品视频yy9099| 日韩国产欧美精品在线| 欧美性感美女h网站在线观看免费| 狠狠色狠狠色综合日日小说| 美女视频黄免费的亚洲男人天堂| 一道本无吗dⅴd在线播放一区| 日韩在线观看免费| 国产有码一区二区| 欧美日韩激情美女| 久久久免费观看视频| 韩国欧美亚洲国产| 日韩亚洲国产中文字幕| 国内精品久久久久伊人av| 久久人人爽人人爽人人片av高清| 亚洲一区二区三区xxx视频| 国产精品一区二区三区成人| 国产精品极品美女在线观看免费| 岛国视频午夜一区免费在线观看| 欧美精品制服第一页| 午夜美女久久久久爽久久| 精品久久久久久久久久久久久| 国产视频久久久久| 亚洲免费一级电影| 国产精品中文在线| 岛国精品视频在线播放| 日韩电影在线观看中文字幕| 性色av一区二区咪爱| 精品丝袜一区二区三区| 亚洲乱码国产乱码精品精| 91九色精品视频| 91国自产精品中文字幕亚洲| 日韩精品www| 亚洲最大福利网站| 久久精品影视伊人网| 国产一区二区三区欧美| 国产一区二区黑人欧美xxxx| 亚洲在线一区二区| 精品成人久久av| 国产mv免费观看入口亚洲| 欧美性受xxx| yellow中文字幕久久| 久久99精品视频一区97| 亚洲精品永久免费| 久久国产精品久久久久| 在线播放精品一区二区三区| 国产精品视频自拍| 国产精品久久久久久网站| 两个人的视频www国产精品| 91精品国产综合久久香蕉的用户体验| 欧美日韩免费看| 亚洲日韩第一页| 久久久精品美女| 国内精品在线一区| 国产视频久久久| 一本色道久久88综合日韩精品| 日韩亚洲国产中文字幕| 亚洲免费精彩视频| 久久久精品影院| 一本色道久久综合狠狠躁篇的优点| 成人黄色中文字幕| 国产精品嫩草影院久久久| 69久久夜色精品国产69| 成人在线免费观看视视频| 97视频免费在线观看| 9.1国产丝袜在线观看| 影音先锋欧美精品| 亚洲人在线观看| 亚洲大胆美女视频| 中文字幕在线看视频国产欧美在线看完整| 成人福利在线观看| 日韩精品极品视频| 亚洲aa中文字幕| 欧美午夜精品久久久久久人妖| 成人激情视频小说免费下载| 欧美成人免费小视频| 尤物九九久久国产精品的分类| 在线电影欧美日韩一区二区私密| 激情av一区二区| 91久久久久久国产精品| 国产免费一区二区三区香蕉精| 欧美日韩另类视频| 91chinesevideo永久地址| 亚洲日韩中文字幕在线播放| 亚洲自拍偷拍色片视频| 国产成人欧美在线观看| 欧美亚洲午夜视频在线观看| 91久久久精品| 91精品视频大全| 综合国产在线视频| 国产精品久久久久久五月尺| 日本成人精品在线| 国产精品久久精品| 久久久久久69| 欧美性一区二区三区|