ES6中解构赋值的使用讲解
程序员文章站
2022-03-05 07:53:31
...
本篇文章给大家带来的内容是关于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中解构赋值的使用讲解的详细内容,更多请关注其它相关文章!
上一篇: vue 日期不能选择某一天之前的日期
下一篇: javascript是由那几个部分组成
推荐阅读
-
JS中cookie的使用及缺点讲解
-
JQuery Ajax 在asp.net中的使用并调用后台实例讲解
-
JavaEE基础day02 1.定义Java中的变量 四类八种 2.变量定义和使用的注意事项 3.数据类型的转换、强制数据类型转换4.算数运算符、比较运算符、逻辑运算符、赋值运算符、三元运算符
-
Python中的pass语句使用方法讲解
-
react开发中如何使用require.ensure加载es6风格的组件
-
ES6第二章 关于“变量的解构赋值”不得不说的事~
-
ES6之变量的解构赋值
-
现代JavaScript使用技巧之ES6中的简写语法
-
ES6中的解构、扩展运算符(...)、rest参数(...)的使用
-
ES6中字符串的使用方法扩展