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实现鼠标移到Image上方时显示文字效果的方法
Aug 07 Javascript
浅谈Angular中ngModel的$render
Oct 24 Javascript
微信小程序 绘图之饼图实现
Oct 24 Javascript
jquery延迟对象解析
Oct 26 Javascript
javascript replace()第二个参数为函数时的参数用法
Dec 26 Javascript
bootstrap table配置参数例子
Jan 05 Javascript
js+css3实现旋转效果
Jan 20 Javascript
js模块加载方式浅析
Aug 12 Javascript
vue综合组件间的通信详解
Nov 06 Javascript
Vue完整项目构建(进阶篇)
Feb 10 Javascript
详解小程序不同页面之间通讯的解决方案
Nov 23 Javascript
给原生html中添加水印遮罩层的实现示例
Apr 02 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 文件上传系统手记
2009/10/26 PHP
PHP无法访问远程mysql的问题分析及解决
2013/05/16 PHP
php实现计数器方法小结
2015/01/05 PHP
php爬取天猫和淘宝商品数据
2018/02/23 PHP
PHP中Static(静态)关键字功能与用法实例分析
2019/04/05 PHP
JS焦点图切换,上下翻转
2011/05/12 Javascript
js定时调用方法成功后并停止调用示例
2014/04/08 Javascript
js实现点击后将文字或图片复制到剪贴板的方法
2014/08/04 Javascript
jQuery中slideUp 和 slideDown 的点击事件
2015/02/26 Javascript
jQuery插件boxScroll实现图片轮播特效
2015/07/14 Javascript
JavaScript实现简洁的俄罗斯方块完整实例
2016/03/01 Javascript
jQuery简单注册和禁用全局事件的方法
2016/07/25 Javascript
jQuery中slidedown与slideup方法用法示例
2016/09/16 Javascript
node.js中express-session配置项详解
2017/05/31 Javascript
微信小程序实现页面跳转传值的方法
2017/10/12 Javascript
nodejs 最新版安装npm 的使用详解
2018/01/18 NodeJs
使用jquery DataTable和ajax向页面显示数据列表的方法
2018/08/09 jQuery
原生JS实现简单的无缝自动轮播效果
2018/09/26 Javascript
Vue实现多标签选择器
2019/11/28 Javascript
react-router-dom 嵌套路由的实现
2020/05/02 Javascript
Nuxt默认模板、默认布局和自定义错误页面的实现
2020/05/11 Javascript
vue如何在用户要关闭当前网页时弹出提示的实现
2020/05/31 Javascript
[01:57]2018DOTA2亚洲邀请赛赛前采访-iG
2018/04/03 DOTA
[44:10]2018DOTA2亚洲邀请赛 4.5 淘汰赛 EG vs VP 第一场
2018/04/06 DOTA
python实现zabbix发送短信脚本
2018/09/17 Python
Python初学者需要注意的事项小结(python2与python3)
2018/09/26 Python
Python删除n行后的其他行方法
2019/01/28 Python
python和C++共享内存传输图像的示例
2020/10/27 Python
HTML5本地存储之Database Storage应用介绍
2013/01/06 HTML / CSS
Servlet方面面试题
2016/09/28 面试题
幼儿园大班新学期寄语
2014/01/18 职场文书
灰雀教学反思
2014/04/28 职场文书
python 三边测量定位的实现代码
2021/04/22 Python
浅谈pytorch中stack和cat的及to_tensor的坑
2021/05/20 Python
SpringBoot+Vue+JWT的前后端分离登录认证详细步骤
2021/09/25 Java/Android
Golang ort 中的sortInts 方法
2022/04/24 Golang