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 相关文章推荐
一个CSS+jQuery实现的放大缩小动画效果
Feb 19 Javascript
JS实现常见的TAB、弹出层效果(TAB标签,斑马线,遮罩层等)
Oct 08 Javascript
JavaScript原生xmlHttp与jquery的ajax方法json数据格式实例
Dec 04 Javascript
Vue.js每天必学之表单控件绑定
Sep 05 Javascript
微信小程序 HTTPS报错整理常见问题及解决方案
Dec 14 Javascript
基于ajax和jsonp的原生封装(实例)
Oct 16 Javascript
elementui的默认样式修改方法
Feb 23 Javascript
详解vue-router 初始化时做了什么
Jun 11 Javascript
微信小程序自定义底部弹出框
Nov 16 Javascript
基于Vue实现可以拖拽的树形表格实例详解
Oct 18 Javascript
10个最受欢迎的 JavaScript框架(推荐)
Apr 24 Javascript
vue 实现用户登录方式的切换功能
Apr 14 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
php利用反射实现插件机制的方法
2015/03/14 PHP
载入进度条 效果
2006/07/08 Javascript
javascript(jquery)利用函数修改全局变量的代码
2009/11/02 Javascript
javascript拓展DOM操作 prependChild insertAfert
2010/11/17 Javascript
js的一些常用方法小结
2011/06/29 Javascript
固定背景实现的背景滚动特效示例分享
2013/05/19 Javascript
js判断背景图片是否加载成功使用img的width实现
2013/05/29 Javascript
Javascript弹出窗口的各种方法总结
2013/11/11 Javascript
jquery通过closest选择器修改上级元素的方法
2015/03/17 Javascript
javascript实现类似于新浪微博搜索框弹出效果的方法
2015/07/27 Javascript
快速获取/设置iframe内对象元素的几种js实现方法
2016/05/20 Javascript
JS DOMReady事件的六种实现方法总结
2016/11/23 Javascript
JS实现重新加载当前页面或者父页面的几种方法
2016/11/30 Javascript
jQuery的事件预绑定
2016/12/05 Javascript
jQuery实现可拖拽3D万花筒旋转特效
2017/01/03 Javascript
基于JavaScript实现窗口拖动效果
2017/01/18 Javascript
JS请求servlet功能示例
2017/06/01 Javascript
jQuery选择器之子元素选择器详解
2017/09/18 jQuery
JavaScript 下载svg图片为png格式
2018/06/21 Javascript
js中null与空字符串""的区别讲解
2019/01/17 Javascript
js JSON.stringify()基础详解
2019/06/19 Javascript
layui上传图片到服务器的非项目目录下的方法
2019/09/26 Javascript
vue中实现弹出层动画效果的示例代码
2020/09/25 Javascript
Python实现合并字典的方法
2015/07/07 Python
Python常用时间操作总结【取得当前时间、时间函数、应用等】
2017/05/11 Python
scrapy爬虫实例分享
2017/12/28 Python
Django之模型层多表操作的实现
2019/01/08 Python
Python使用dict.fromkeys()快速生成一个字典示例
2019/04/24 Python
如何使用Python多线程测试并发漏洞
2019/12/18 Python
Python 日期与时间转换的方法
2020/08/01 Python
节约电力资源的建议书
2014/03/12 职场文书
社区端午节活动总结
2015/02/11 职场文书
Nginx部署vue项目和配置代理的问题解析
2021/08/04 Servers
Python3.8官网文档之类的基础语法阅读
2021/09/04 Python
MongoDB数据库部署环境准备及使用介绍
2022/03/21 MongoDB
利用nginx搭建RTMP视频点播、直播、HLS服务器
2022/05/25 Servers