前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ES6系列_3之变量的解构赋值

ES6系列_3之变量的解构赋值

作者头像
wfaceboss
发布2019-04-08 10:37:55
3730
发布2019-04-08 10:37:55
举报
文章被收录于专栏:wfacebosswfaceboss

ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构。

解构有三种类型:

1.数组的解构赋值

(1)简单的数组解构

以前,我们给变量赋值是直接单个指定值,比如:

代码语言:javascript
复制
let a=0;
let b=1;
let c=2;

数组解构的方式来进行赋值,如下:

代码语言:javascript
复制
let  [a,b,c]=[1,2,3];

总结:从数组中提取值,按照位置的对象关系(次序)对变量赋值。

(2)数组模式和赋值模式统一

可以简单的理解为等号左边和等号右边的形式要统一,如果不统一解构将失败。相关代码如下:

代码语言:javascript
复制
let [a,[b,c],d]=[1,[2,3],4];

如果等号两边形式不一样,很可能获得undefined或者直接报错。

(3)解构的默认值

解构赋值是允许你使用默认值的,相关代码如下:

代码语言:javascript
复制
let [foo = true] =[];
console.log(foo); //控制台打印出true

undefined和null的区别:

*undefined相当于什么都没有。

*null相当于有值,但值为null。

2.对象的解构赋值

对象的属性没有次序,变量必须与属性同名,才能取到正确的值。

(1)圆括号的使用

如果在解构之前就定义了变量,这时候再解构会出现问题,而且编译就会报错。

代码语言:javascript
复制
let foo;
{foo} ={foo:'i love you'};
console.log(foo);

要解决报错,使程序正常,我们这时候只要在解构的语句外边加一个圆括号就可以了。

代码语言:javascript
复制
let foo;
({foo} ={foo:'i love you'});
console.log(foo); //控制台输出i love you

3.字符串解构

字符串解构,此时字符串被转换成了一个类似数组的对象。

代码语言:javascript
复制
const [a,b,c,d,]="love";
console.log(a);//l
console.log(b);//o
console.log(c);//v
console.log(d);//e

学习参考链接为:http://jspang.com/post/es6.html#toc-696 。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-12-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.数组的解构赋值
  • 2.对象的解构赋值
  • 3.字符串解构
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档