ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring). 关于给变量赋值,传统的变量赋值是这样的: var arr = [1,2,3];//把数组的值分别赋给下面的变量: var a = arr[0]; var b = arr[1]; var c = arr[2]; console.log(a);//a的值为1 console.log(b);//b的值为2 console.log(c);//c的值为3 变量的解构赋值: var [a,b,c] =
解构的作用:简化书写长度,提升开发效率. 解构对象 在开发中我们常用到使用ajax请求数据,并且把数据渲染到页面上.可能这个数据返回的对象或数组.例如返回一个obj{name:'zwq',age:18,sex:woman}而我们获取里面的值保存在变量里会用 var name = obj.name,var age = obj.age. 在es6中提供了解构的语法糖,让左右两侧极为相似的结构进行变量赋值. 在对象中单独写一个name代表的就是 name:name,左侧name你要到对象对象找到的属性
解构赋值是对赋值运算符的扩展,可以将属性/值从对象/数组中取出,赋值给其他变量. 一.数组的解构赋值 1.基本用法 只要等号两边的模式相同,左边的变量就会被赋予对应的值. let [a, [[b], c]] = [1, [[2], 3]]; a b c let [a, , c] = [1, 2, 3]; a c // 3 let [a, ...c] = [1, 2, 3, 4]; a c // [2, 3, 4] let [a, b, ...c] = [1]; a b // undefined
定义 ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构 数组的解构赋值 以前,为变量赋值,只能直接指定值. let a = 1; let b = 2; let c = 3; es6写法 let [a, b, c] = [1, 2, 3]; 不完全解构--解构不成功,值都会等于undefined let [x, y, ...z] = ['a']; x // "a" y // undefined z // [] let [bar, foo] = [1]; foo