亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ES6入門教程之變量的解構賦值詳解

發布時間:2020-10-09 00:34:07 來源:腳本之家 閱讀:151 作者:故事膠片 欄目:web開發

前言

我們經常定義許多對象和數組,然后有組織地從中提取相關的信息片段。在ES6中添加了可以簡化這種任務的新特性:解構。解構是一種打破數據結構,將其拆分為更小部分的過程。本文將詳細介紹ES6解構賦值,下面話不多說了,來一起看看詳細的介紹吧

數組的解構賦值

基本用法

ES6 允許按照一定模式,從數組和對象中提取值,對變量進行賦值,這被稱為結構。

在ES6之前想要為變量賦值,只能指定其值,如下:

let a = 1;
let b = 2

而在ES6中可以寫成這樣,如下:

let [a,b] = [1,2]
// a = 1, b = 2

值得注意的是,等式兩邊的值要對等,這樣左邊的變量才會被賦上右邊對應的值,如果不對等左邊的值將會出現undefined,如下寫法:

let [foo,[[bar],baz]] = [1,[[2],3]]
foo // 1
bar // 2
baz // 3

 

注意:只有左右兩邊的 格式一定要對等,數量可以不對等。

let [a,b,c] = [1,2]
a = 1, b = 2, c = undefined

let [a,,c] = [1,2,3]
a = 1, c = 3

let [a, ...b] = [1,2,3]
a = 1, b = [2,3]

let [a] = []
let [b,a] = [1]
a = undefined

還有一種情況,等號左邊為數組,但是等號右邊為其他值,將會報錯。如下:

let [a] = 1;
let [a] = false;
let [a] = NaN;
let [a] = undefined;
let [a] = null;
let [a] = {};

以上都會報錯

但是如果左邊為數組,右邊為字符串,將會取字符串的第一個下標的值

let [a] = '121321' a = '1'
let [a] = 'adgasg' a = 'a'

對于Set結構,同樣可以使用數組的解構賦值。

let [x,y,z] = new Set([1,2,3])
x = 1, y = 2, z = 3

默認值

解構賦值允許指定默認值

let [a = 3] = [] // a:3
let [a = 3,b] = [,4] // a:3 b:4
let [a = 3,b] = [5,4] // a:5 b:4

特殊

let [a = 3] = [undefined] // a:3
let [a = 3] = [null] // a:null

Tips: 在es6中使用嚴格相等運算符,在結構賦值中如果需要默認值生效,則應對等的值為undefined的時候才會采用默認值,否則還是使用賦值。上面中null 不嚴格等于undefined++

如果默認值的賦值為一個表達式,只有當等號右邊的賦值沒有值為undefined的時候,才會取表達式中的值,如下:

function demo(){
 console.log('demo')
}

let [a = demo()] = [] // a: demo
let [a = demo()] = [1] // a : 1

對象的解構賦值

與數組的不同點是,數組的元素必須和賦值的元素要位置一致才能正確的賦值,而對象的解構賦值則是等號兩邊的變量和屬性同名即可取到正確的值。否則值為 undefined

let {a,b} = {a:'23',b:'3'}
let {a,b} = {b:'3',a:'23'}

// 上面兩個的值 都是 a: 23 b: 3

let {a,b} = {a:'3',c:'d'}
//a: 3 b: undefined

對象的解構賦值還有將某一個現有對象的方法賦值到一個新的變量,如下:

let {sin,cos} = Math
// Math 中的sin cos 方法將賦值給變量 sin cos

let {log} = console
// log(2) === console.log(2)

如果等號左邊的變量名不能和等號右邊的對象的屬性名一致,則必須寫成如下格式:

let {a:b} = {a:'ss'} // b:ss
//a是屬性名,b才是實際賦值的變量名

對象的解構賦值一樣是可以嵌套解構的,如下:

第一種:

let obj = {
	p:[
		'Hello',
 {y:'world'}
	]
}

let {p:[x,{y}]} = obj 
// x: Hello, y: world

這邊的p只是屬性不是變量,如果p想賦值可以寫成:

let {p,:[x,{y}]} = obj

第二種:
const a = {
	loc: {
		t :1,
		b :{
			c:1,
			d:2	
		}
	}
}
let {loc:{t,b:{c,d}}} = a
或者
let {loc,loc:{t,b,b:{c,d}}} = a

嵌套賦值

let o = {}, arr = []

({foo:o.prop,bar: arr[0]} = {foo:123,bar:true})
//o: 123, arr = [true]

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

let {foo:{bar}} = {baz:'baz'} //報錯

默認值

let {x = 3} = {}
// x: 3

let {x,y = 5} = {x : 1}
// x: 1, y: 5

let {x: y = 5} = {}
// y = 5

let {x: y = 5} = {x : 4}
// y = 4

let {x: y = 'hhhh'} = {}
//y = 'hhhh'

Tips:以上左邊 x為屬性名,y為變量


let {x = 5} = {x: undefined}
// x: 5

let {x = 4} = {x: null}
// x: null

同數組一樣遵循 嚴格等于 
只有右邊為undefined的時候默認值才會生效

注意點:

1)不能將已聲明的變量用于解構賦值,因為已經是一個代碼塊。

字符串的解構賦值

如果賦值的對象是數組,字符串將被分割為數組的格式,一一對應賦值

let [a,b] = 'ha'
// a = h , b = a

同時可以獲得字符串的長度:

let {length:len} = '12121'
// len = 5

數值和布爾值的解構賦值

如果等號右邊是數字或者布爾值 則轉換成對象或者說,除了是數組和對象,其他值都將轉換成對象,null 和 undefined 除外。如下:

let {t:s} = 123
let {t: s} = true

函數參數的解構賦值

function add([x,y]){
 return x+y
}
add([3,5]) // 8

[[3,5],[6,7]].map(([a,b]) => a + b)
//8 , 13

function m({x=3, y=4} = {}){
 return [x,y]
}
m({x:33,y:8})  // [33,8]
m({x:32})   // [32,4]
m({})    // [3,4]
m()    // [3,4]

function m({x,y} = {x=0,y=0}){
 return [x,y]
}
m({x:33,y:8})  // [33,8]
// 代替右邊的 x:0, y:0 所以是傳值 33 8

m({x:32})   // [32,undefined]
//因為傳值替代右邊的賦值,但是只有x沒有y
//所以y是取 左邊y的默認值,因為你沒有賦值 為undefined

m({})    // [undefined,undefined] 
// 取左邊x,y的默認值,因為沒有賦值 為undefined

m()    // [0,0]
// 沒有傳值,使用本身的賦值 都是0

其他

不能使用圓括號的情況

  • 變量聲明語句
  • 函數參數
  • 賦值語句的模式

可以使用圓括號的情況

  • 賦值語句的非模式部分,可以使用圓括號

解構賦值的用途

  • 交換變量的值
  • 從函數返回多個值
  • 函數參數的定義
  • 提取JOSN數據
  • 函數參數的默認值
  • 遍歷Map結構
  • 輸入模塊的指定方法

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

仁寿县| 桦南县| 隆化县| 宣城市| 宁蒗| 灵宝市| 孟连| 尤溪县| 额敏县| 郁南县| 礼泉县| 马公市| 阳泉市| 扎兰屯市| 汨罗市| 甘德县| 南投市| 五台县| 平定县| 鄂托克前旗| 信宜市| 资阳市| 会同县| 宁乡县| 江阴市| 苍南县| 大石桥市| 卓资县| 凤庆县| 滨州市| 临安市| 乌鲁木齐市| 深泽县| 铜梁县| 梓潼县| 松原市| 天柱县| 长子县| 焦作市| 宁强县| 海淀区|