首頁 > web前端 > js教程 > ES6中解構賦值的使用講解

ES6中解構賦值的使用講解

不言
發布: 2018-11-14 15:45:21
轉載
1988 人瀏覽過

這篇文章帶給大家的內容是關於ES6中解構賦值的使用講解,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。

概述

實不相瞞,解構賦值非常叼,特別是和其他es6一起使用的時候,那如何簡單的說解構賦值呢,打個比方:解構賦值就是一個硬幣分割機,將所有的一毛、五毛、一塊硬幣投入硬幣分割機,他就自動將所有的硬幣分好了,拿出你要的就行了!

解構數組

可以從一個陣列從取出你想要的一個資料或是一組資料

普通

let [a, b, c]=[1,2,3]
console.log(a) // 1
console.log(b) // 2
console.log(c) // 3
登入後複製

和剩餘參數一起用

let [a, b, ...c]=[1,2,3,4,5]
console.log(a) // 1
console.log(b) // 2
console.log(c) // [3,4,5]
登入後複製

省略一些參數

let [a, , ...c]=[1,2,3,4,5]
console.log(a) // 1
console.log(c) // [3,4,5]
登入後複製

參數不夠

let [a, b, c]=[1,2]
console.log(a) // 1
console.log(b) // 2
console.log(c) // undefined
登入後複製

參數不夠又不想要undefined,可以使用預設參數

let [a, b, c=3]=[1,2]
console.log(a) // 1
console.log(b) // 2
console.log(c) // 3
登入後複製

對已有變數解構賦值

let a, b
[a, b]=[1,2]
console.log(a, b)// 1,2
登入後複製

有趣的陣列解構栗子

交換兩個變數

let a=1,b=2
[a, b]=[b, a]
console.log(a) // 2
console.log(b) // 1
登入後複製

取得一個正規匹配的結果

let [,match]="hello world".match(/h(e)/) 
// 匹配的结果是 ["he", "e", index: 0, input: "hello world", groups: undefined]

console.log(match) // 'e'
登入後複製

#解構物件

可以從物件中取出物件的一個屬性值,或一個子物件

普通

let {a, b}={a:1,b:2}
console.log(a) // 1
console.log(b) // 2
登入後複製

剩餘屬性

let {a,...b}={a:1,b:2,c:3}
console.log(a) // 1
console.log(b) // {b:2,c:3}
登入後複製

屬性不夠

let {a, b, c}={a:1,b:2}
console.log(a) // 1
console.log(b) // 2
console.log(c) // undefined
登入後複製

屬性不夠可以使用預設參數

let {a, b, c=3}={a:1,b:2}
console.log(a) // 1
console.log(b) // 2
console.log(c) // 3
登入後複製

給新的變數賦值

let {a:aa, b:bb}={a:1,b:2}
console.log(aa) // 1
console.log(bb) // 2
登入後複製

給新的變數賦值並提供預設值

let {a:aa, b:bb, c:cc=3}={a:1,b:2}
console.log(aa) // 1
console.log(bb) // 2
console.log(cc) // 3
登入後複製

很深的物件也可以解構

let {name, books:[book]}={name:"haha",books:['book1']}
console.log(name) // 'haha'
console.log(book) // 'book1'
登入後複製

迭代中的解構

for(let {name} of [{name:1},{name:2}]){
    console.log(name) // 1 2
}
登入後複製

解構函數形參

let register({name, pwd}){
    console.log(name, pwd)
}
register({name:'1',pwd:'2'}) //1,2
登入後複製

給已有變數賦值,比較特殊

let a,b
({a, b}={a:1,b:2}) // 需要提升优先级,否则 {a, b} 会被解析成代码块
console.log(a, b)// 1, 2
登入後複製

以上是ES6中解構賦值的使用講解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:https://segmentfault.com/a/1190000016988939
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板