解构通俗点说,就是通过一种特定格式,快捷的读取对象/数组中的数据的方法,

es6之前,我们通过对象名称[键] 读取数据

         var User = {
'name' : 'ghostwu',
'age' : 22
};
console.log( User.name, User.age ); //ghostwu, 22
         var User = {
'name' : 'ghostwu',
'age' : 22
};
let { name, age } = User;
console.log( name, age ); //ghostwu 22

上面第5行就是一个简单的数据解构过程:

1,右边如果是对象,左边解构的语法也要用对象格式, 如果解构的数据是数组,左边就用数组格式
2,name, age是局部变量
3,解构出来的变量 一定要是 对象中能够查找到的属性名
4,如果解构出来的属性在对象中查找不到,值为undefined
         var User = {
'name' : 'ghostwu',
'age' : 22
};
let { name1, age1 } = User;
console.log( name1, age1 ); //undefined, undefined

解构出来的变量虽然是跟属性名称相同,但是他不再是属性,而是外部的变量,这个变量名也可以被修改, 不一定要跟属性同名

         var User = {
'name' : 'ghostwu',
'age' : 22
};
//解构出来的变量可以更改名称
let { name : name1, age : age1 } = User;
// console.log( name, age ); //报错, 因为name和age的名称已经被改了
console.log( name1, age1 ); //ghost, 22

更改解构出来的变量名称的语法:  旧的名称 : 新的名称

         var User = {
'name': 'ghostwu',
'age': 22
}; let { name, age, sex } = User;
// 解构出来的属性,如果不存在,默认值为undefined
console.log( name, age, sex ); //ghost 22 undefined
        var User = {
'name': 'ghostwu',
'age': 22
};
// 解构出来的值 可以赋值 一个默认的值
let { name, age, sex = 'man' } = User;
console.log( name, age, sex );

上述实例,为sex赋值了一个默认值 'man';

解构数组

         let arr = [ 10, 20, 30, 40 ];

         // 数组用[]解构
let [ one, two ] = arr;
console.log( one, two ); //10 20
 let arr = [ 10, 20, 30, 40 ];
// 对于不需要解构的值,可以用逗号占位
let [ , , , a ] = arr;
console.log( a ); //

解构嵌套数组

         let arr = [ 10, [ 20, 30 ], 40 ];
console.log( arr[1][1] ); //
let [ one, two, three, four ] = arr;
console.log( one, two, three, four ); //10 [20, 30] 40 undefined
[ one, [ two, three ], four ] = arr; //前面不要let,否则会报重定义错误
console.log( one, two, three, four ); //10 20 30 40

在以前,我们交换变量,一般的做法是借助第三个变量, 而现在有了解构之后,我们可以直接交换

         /*
交换两个变量的值
*/
let a = 10, b = 20;
[ a, b ] = [ b, a ]; //前面不要加let,否则会报 重定义错误
console.log( a, b ); //20, 10

利用解构出来的值,修改局部变量的值

         let User = {
name : 'ghostwu',
age : 22
},
name = 'zhangsan',
age = 30; //小括号: 把下面这个 转成解构表达式, 如果不用小括号会报错
({ name, age } = User);
console.log( name, age ); //ghostwu, 22
         let name = 'zhangsan', age = 40;
({ name, age } = {
name,
age
}); console.log( name, age ); //zhangsan 40

上述实例,是一个对象赋值的简写语法,你还记得吗?

         let User = {
name : 'ghostwu',
age : 22
}; //重命名局部变量,mySex:赋初始值
let { name : myName, age : myAge, sex : mySex = 'man' } = User;
console.log( myName, myAge, mySex ); //ghostwu 22 man

解构表达式传参

         let User = {
name : 'ghostwu',
age : 22
}; function show( obj ){
console.log( obj ); //obj其实就是User对象
console.log( obj === User ); //true
//函数中可以访问在参数中解构出来的变量
console.log( name, age ); //ghostwu, 22
}
show( { name, age } = User ); //表达式传值,整个表达式的值 取决于右边,所以把User传给了obj
console.log( name, age ); //ghostwu, 22

嵌套对象的解构

         let User = {
name : 'ghostwu',
age : 22,
class : {
group1 : {
one : '王超',
two : '马汉'
},
group2 : {
one : '张龙',
two : '赵虎'
}
}
};
//在User对象解构class, 在class中解构group1
let { class : { group1 } } = User;
console.log( group1.one ); //王超
console.log( group1.two ); //马汉 //在User对象解构class, 在class中解构group1, 在group1中解构one, two
({ class : { group1 : { one, two } } } = User);
console.log( one, two ); //王超, 马汉 //重命名group1 为 diyizu
({ class : { group1 : diyizu } } = User);
console.log( diyizu.one ); //王超
console.log( diyizu.two ); //马汉 //three 赋默认值
({ class : { group1 : { one, two, three = '展昭' } } } = User);
console.log( one, two, three );//王超,马汉,展昭

解构中的不定参数(...)

        let arr = [ 10, 20, 30 ];
let [ one, ...others ] = arr;
console.log( others.length ); //
console.log( one ); //
console.log( others[0] ); //
console.log( others[1] ); //
         //es6之前,用concat复制数组
let arr = [ 10, 20, 30 ];
let newArr = arr.concat();
console.log( newArr );
         //用解构与不定参数结合 复制 数组
let arr = [ 10, 20, 30 ];
let [ ...newArr ] = arr;
console.log( newArr );

最后一道综合练习题: 对象与数组的混合解构,能看懂,基本就算掌握了

         let User = {
name : 'ghostwu',
age : 22,
class : {
group1 : {
one : '王超',
two : '马汉'
},
group2 : {
one : '张龙',
two : '赵虎'
}
},
arr : [ 10, 20, 30 ]
}; // let { name, age, class : { group1 }, arr } = User;
let { name, age, class : { group1, group2 }, arr : [ one, two, three ] } = User;
// console.log( name, age, group1.one, group1.two, arr );
console.log( name, age, group1.one, group1.two, group2.one, group2.two, one, two, three );

[js高手之路]es6系列教程 - 解构详解的更多相关文章

  1. [js高手之路] es6系列教程 - 箭头函数详解

    箭头函数是es6新增的非常有意思的特性,初次写起来,可能会觉得别扭,习惯之后,会发现很精简. 什么是箭头函数? 箭头函数是一种使用箭头( => )定义函数的新语法, 主要有以下特性: 不能通过n ...

  2. [js高手之路] es6系列教程 - 对象功能扩展详解

    第一:字面量对象的方法,支持缩写形式 //es6之前,这么写 var User = { name : 'ghostwu', showName : function(){ return this.nam ...

  3. [js高手之路] es6系列教程 - 迭代器,生成器,for...of,entries,values,keys等详解

    接着上文[js高手之路] es6系列教程 - 迭代器与生成器详解继续. 在es6中引入了一个新的循环结构for ....of, 主要是用来循环可迭代的对象,那么什么是可迭代的对象呢? 可迭代的对象一般 ...

  4. [js高手之路] es6系列教程 - 迭代器与生成器详解

    什么是迭代器? 迭代器是一种特殊对象,这种对象具有以下特点: 1,所有对象都有一个next方法 2,每次调用next方法,都会返回一个对象,该对象包含两个属性,一个是value, 表示下一个将要返回的 ...

  5. [js高手之路] es6系列教程 - promise常见用法详解(resolve,reject,catch,then,all,race)

    关于promise我在之前的文章已经应用过好几次,如[js高手之路]Node.js+jade+express+mongodb+mongoose+promise实现todolist,本文就来讲解下pro ...

  6. [js高手之路] es6系列教程 - 函数的默认参数详解

    在ES6之前,我们一般用短路表达式处理默认参数 function show( a, b ){ var a = a || 10; var b = b || 20; console.log( a, b ) ...

  7. [js高手之路] es6系列教程 - var, let, const详解

    function show( flag ){ console.log( a ); if( flag ){ var a = 'ghostwu'; return a; } else { console.l ...

  8. [js高手之路] es6系列教程 - Set详解与抽奖程序应用实战

    我们还是从一些现有的需求和问题出发,为什么会有set,他的存在是为了解决什么问题? 我们看一个这样的例子,为一个对象添加键值对 var obj = Object.create( null ); obj ...

  9. [js高手之路] es6系列教程 - Map详解以及常用api

    ECMAScript 6中的Map类型是一种存储着许多键值对的有序列表.键值对支持所有的数据类型. 键 0 和 ‘0’会被当做两个不同的键,不会发生强制类型转换. 如何使用Map? let map = ...

随机推荐

  1. 关于MATLAB处理大数据坐标文件2017529

    今天我们离成功又近了一步,因为又失败了两次 第一次使用了所有特征,理由:前天的特征使用的是取单个特征测试超过85分的特征,结果出现过拟合现象. 本次使用所有特征是为了和昨天的结果作比较. 结果稍好:比 ...

  2. dubbo与zookeeper的关系

    Dubbo建议使用Zookeeper作为服务的注册中心. 1.   Zookeeper的作用: zookeeper用来注册服务和进行负载均衡,哪一个服务由哪一个机器来提供必需让调用者知道,简单来说就是 ...

  3. 邪恶改装2:用单片机实现一次简单的wifi密码欺骗

    0×00 前言 前段时间用TPYBoard v202 做了一个简单的WIFI干扰攻击器(ps :没有看过的小伙伴,可以看一下:http://www.freebuf.com/column/136985. ...

  4. Python3.5学习笔记-文件操作

    在Python中,操作文件对象使用open函数来创建,下表列出了常用的操作file的函数: 序号 方法及描述 1.file.close() 关闭文件.关闭后文件不能再进行读写操作. 2.file.fl ...

  5. 正则表达式获取body内容

    最近项目需要,要弄个正则表达式获取body的内容. 用过angularjs就知道,很多时候要写指令时引用templateUrl的时候.template的内容root是不能包含多个节点的,否则就报错. ...

  6. VB6之GDI+加载PNG图片

    原生的VB6不支持PNG个图片,因为刚有VB的时候还没有PNG的概念呢.不过,利用GDI+加载解析个PNG简直是砍瓜切菜般简单. GDI+的模块是我在网上下载的,地址应该是:http://vistas ...

  7. PHP源码阅读strtr

    strtr 转换字符串中特定的字符,但是这个函数使用的方式多种. echo strtr('hello world', 'hw', 'ab'); // 第一种 aello borld echo strt ...

  8. Oracle索引批量重置笔记

    ---单个索引重置语句 alter index indexname  rebuild; ---查询数据索引对象语句 select *  from user_indexes; ------将数据库的索引 ...

  9. springmvc中的page

    1.1在page类上面要打个service的注解,这样page才能传过去1.2 在page中都是写private String XX;然后source实现传值的set,get的方法, package ...

  10. Python如何实现单步调试

    遇到大型python项目,如何定位问题和监控程序的运行状态是一个程序员必须掌握的技能,今天小编为你带来python程序的单步调试方法,方便易用,简单易记! 首先你需要在所调试程序的开头中:import ...