脚本宝典收集整理的这篇文章主要介绍了es6基础0x008:解构赋值,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
0x000 概述
实不相瞒,解构赋值非常叼,特别是和其他es6
一起使用的时候,那如何简单的说解构赋值
呢,打个比方:解构赋值就是一个硬币拆分机,将所有的一毛、五毛、一块硬币投入硬币拆分机,他就自动将所有的硬币分好了,拿出你要的就行了!
0x001 解构数组
-
普通
@H_512_25@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
-
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
0x002 有趣的数组解构栗子
-
交换两个变量
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'
0x003 解构对象
可以从对象中取出对象的一个属性值,或者一个子对象
-
普通
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基础0x008:解构赋值全部内容,希望文章能够帮你解决es6基础0x008:解构赋值所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。