ECMAScript6--解构


Posted in Javascript onMarch 30, 2017

大致介绍

解构:就是将声明的一组变量和与相同结构的数组或者对象的元素数值一一对应,并将变量相对应元素进行赋值

数组解构

例子:

let [a,b,c] = [1,2,3];
 console.log(a); //1
 console.log([a,b,c]); //[1, 2, 3]

可以看到,数组中的a,b,c分别对应1,2,3

嵌套的数组也可以进行解构

let [a,[b,[c]]] = [1,[2,[3]]];
 console.log(c); //3

 let [d,,e] = [1,2,3];
 console.log(e); //3

 let [f,...tail] = [1,2,3];
 console.log(tail); //[2, 3]

在解构不成功时,变量的值就是undefined

let [a,b] = [1];
 console.log(b); //undefined

不完全解构也是可以的

let [a,b,c] = [1,2,3,4];
 console.log(c); //3

也可以设置默认值

let [a = 1] = [];
 console.log(a); //1

 let [b = 1] = [2];
 console.log(b); //2

 let [c = 1] = [undefined];
 console.log(c); //1

 let [d = 1] = [null];
 console.log(d); //null

注意:在ES6中使用严格相等运算符(===)。所以如果默认值不严格相等undefined,默认值就不会生效。例如null

默认值也可以是表达式,但是要注意只有默认值在使用时才会触发函数(惰性求值)

function f(){
  alert(1);
 }
 let [a = f()] = [3]; //f()不会执行
 let [b = f()] = [undefined]; //会执行

对象解构

例子:

let {foo,bar} = {foo:1,bar:2};
 console.log(foo); //1

注意:与数组不同,对象解构时不是根据位置对变量赋值的,而是通过变量名进行赋值,即变量名和属性名必须相等才可以进行赋值,位置不重要

let {bar,foo} = {foo:1,bar:2};
 console.log(foo);//1

如果变量名和属性名不相同,则要采取下面的方法

let {first: f,last: l} = {first:1,last:3};
 console.log(l); //3

意思就是先在对象中查找first属性,如果有就赋值给f,其中first是匹配的模式,而f才是真正的变量

所以对象解构的完整形式是:

let {first: first,last: last} = {first:1,last:3}; 

对象解构也可以进行嵌套

let obj = {
  a:1,
  b:[
   'hello',
   {c:'world'}
  ]
 }
 let {a: a,b: [h,{c:w}]} = obj;
 console.log(a); //1
 console.log(h); //hello
 console.log(w); //world

对象解构也可以设置默认值,并且如果解构失败,变量会赋值undefined

let {x: x = 1,y: y=2,z: z=3,w: w} = {x:3,y:null,z:undefined};
 console.log(x) //3
 console.log(y) //null
 console.log(z) //3
 console.log(w) //undefined

字符串解构

字符串之所以能够解构是因为此时字符串转换成了一个数组

let [a,b,c] = 'hello';
 console.log(a); //h
 console.log(b); //e
 console.log(c); //l

数值和布尔值解构

解构赋值时,如果等号右边是数值和布尔值,则会先转为对象

let {toString: s} = 123;
s === Number.prototype.toString // true

let {toString: a} = true;
a === Boolean.prototype.toString // true

上面代码中,数值和布尔值的包装对象都有tostring属性,因此变量s都能取到值。

解构赋值的规则是,只要等号右边的值不是对象或数组,就先将其转为对象。由于null和undefined无法转为对象,所以对它们进行解构赋值,都会报错。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
javascript实现二分查找法实现代码
Nov 12 Javascript
JQuery获取或设置ckeditor的数据(示例代码)
Nov 15 Javascript
JQuery 在线引用及测试引用是否成功
Jun 24 Javascript
jQuery表格插件datatables用法总结
Sep 05 Javascript
JavaScript将数字转换成大写中文的方法
Mar 23 Javascript
js实现select二级联动下拉菜单
Apr 17 Javascript
JavaScript 判断一个对象{}是否为空对象的简单方法
Oct 09 Javascript
jQuery插件FusionCharts实现的MSBar2D图效果示例【附demo源码】
Mar 24 jQuery
JS控件bootstrap suggest plugin使用方法详解
Mar 25 Javascript
jQuery实现的响应鼠标移动方向插件用法示例【附源码下载】
Aug 28 jQuery
微信小程序获取用户openid的实现
Dec 24 Javascript
简单使用webpack打包文件的实现
Oct 29 Javascript
js图片放大镜效果实现方法详解
Oct 28 #Javascript
js a标签点击事件
Mar 30 #Javascript
JS+html5制作简单音乐播放器
Sep 13 #Javascript
TypeScript入门-接口
Mar 30 #Javascript
如何编写jquery插件
Mar 29 #jQuery
基于JavaScript实现瀑布流效果
Mar 29 #Javascript
Angular动态添加、删除输入框并计算值实例代码
Mar 29 #Javascript
You might like
JAVA/JSP学习系列之六
2006/10/09 PHP
php命令行(cli)模式下报require 加载路径错误的解决方法
2015/11/23 PHP
PHP创建word文档的方法(平台无关)
2016/03/29 PHP
PHP中$GLOBALS['HTTP_RAW_POST_DATA']和$_POST的区别分析
2017/07/03 PHP
使用PHPWord生成word文档的方法详解
2019/06/06 PHP
JS实现鼠标单击与双击事件共存
2014/03/08 Javascript
js unicode 编码解析关于数据转换为中文的两种方法
2014/04/21 Javascript
javascript中动态函数用法实例分析
2015/05/14 Javascript
jQuery实现淡入淡出二级下拉导航菜单的方法
2015/08/28 Javascript
微信小程序 wxapp地图 map详解
2016/10/31 Javascript
JS瀑布流实现方法实例分析
2016/12/19 Javascript
微信小程序实现顶部普通选项卡效果(非swiper)
2020/06/19 Javascript
Vue+axios实现统一接口管理的方法
2018/07/23 Javascript
微信小程序实现无限滚动列表
2020/05/29 Javascript
微信小程序中悬浮窗功能的实现代码
2019/08/02 Javascript
Nodejs + Websocket 指定发送及群聊的实现
2020/01/09 NodeJs
浅谈javascript如何获取文件后缀名
2020/08/07 Javascript
antd Select下拉菜单动态添加option里的内容操作
2020/11/02 Javascript
[43:24]2018DOTA2亚洲邀请赛3月29日 小组赛A组 LGD VS Liquid
2018/03/30 DOTA
python3使用tkinter实现ui界面简单实例
2014/01/10 Python
一些常用的Python爬虫技巧汇总
2016/09/28 Python
Python多进程池 multiprocessing Pool用法示例
2018/09/07 Python
python检测IP地址变化并触发事件
2018/12/26 Python
python如何通过twisted搭建socket服务
2020/02/03 Python
使用Python爬虫爬取小红书完完整整的全过程
2021/01/19 Python
阿联酋优惠券服务:Living Kool
2019/12/12 全球购物
网上常见的一份Linux面试题(多项选择部分)
2014/09/09 面试题
语文教育专业应届生求职信
2013/11/23 职场文书
个人函授自我鉴定
2014/03/25 职场文书
工程承包协议书
2014/10/20 职场文书
单位实习工作证明怎么写
2014/11/02 职场文书
学校工会工作总结2015
2015/05/19 职场文书
2016年寒假家长评语
2015/10/10 职场文书
大学副班长竞选稿
2015/11/21 职场文书
【海涛教你打DOTA】黑鸟第一视角解说
2022/04/01 DOTA
vue修饰符.capture和.self的区别
2022/04/22 Vue.js