1.数组的解构赋值

我们知道以前我们给一个变量赋值要这样如下:


let a = 1;
let b = 2;
let c = 3;

但是ES6出来之后,我们可以这样:


let [a, b, c] = [1, 2, 3]

以上就是从数组中提起值,一一对应赋值,a、b、c分别为1、2、3


let [aa, [[bb], cc]] = [1, [[2], 3]]

aa,bb,cc分别对应1,2,3


let [,,d] = [10, 20, 30];
console.log(d);

d的值为30


let [e, ...f] = [1, 2, 3, 4, 5];

e为1, f为[2,3,4,5]


let [x, y, ...z] = [1];

x为1,y为undefined,z为[],如果没有对应值会等于undefined

解构赋值也允许默认值, 如下:


let [ x = '默认值'] = [];

x的值为默认值


let [ a = 123 ] = [ undefined ];
let [ b = 321 ] = [ null ];

a的值为123,b的值为321,因为ES6中是严格遵循(===),所以只有当数组对应的值为undefined的时候,才能等于默认值

默认值可以引用解构赋值的其他变量,但是这个变量必须得声明过的,如下:


let [ a = 0, b = a] = [];

这里a、b分别为0,0

但是如果这个变量没有声明,就会报错,如下:


let [ a = b, b = 1] = [];

这里就会报错:Uncaught ReferenceError: b is not defined

2.对象的解构赋值


let { a, b } = { a: 1, b: 2 };

a,b的值为1,2

对象解构赋值可以无需按照顺序一一对应,但是括号两边的变量名称和属性名称要相同,才能取到正确值


let { a, b } = { a: 1, c : 2};

a为1,b为undefined,这里b在右边括号中没有对应的属性值与其对应,所以此时b为undefined

如果变量名和属性名不一样,则要按照如下写:


let { aa: fa, bb: fb } = { aa: 1, bb: 2 };

fa为1,fb为2

这里可以说明,对象解构赋值实际上是如下的简写:


let { aa: aa, bb: bb } = { aa: 1, bb: 2}

也就是说,对象的解构赋值的内部机制,是先找到同名属性,然后再赋给对应的变量。真正被赋值的是后者,而不是前者。


let { aa: fa } = { aa: 1 } //fa为 1
//aa为 Uncaught ReferenceError: aa is not defined

这里就说明了,fa是真正被赋值的,此时的aa是模式而不是变量,如果你要让aa为变量,则如下:


{
let { aa: fa, aa } = { aa: 1 };
// aa 为 1
// fa 为 1
}

此时aa为1,bb为1,此时aa就是变量了

当然对象也可以多层嵌套如下:


{
let obj = {
p: [1, { y: 2 }]
} let { p: [x, { y }]} = obj;
console.log(x); // 1
console.log(y); // 2
}

{
let obj = {};
let arr = [];
({a: obj.name, b: arr[0] } = { a: 321, b: 123}); console.log(obj); // { name: 321 }
console.log(arr); // [123]
}

对象解构默认值:


{
let { x = 1 } = {};
console.log(x); //1
} {
let { x : y = 4 } = {};
console.log(y); //4
} {
let { x : y = 4 } = { x: 5};
console.log(y); //5
}

默认属性生效条件必须是对象的属性严格等于undefined,如果是null就不会生效,如下:


{
let { x = 1 } = { x : null};
console.log(x); //null
}

已声明的变量解构赋值:


{
let x;
({ x } = { x : 1 });
console.log(1); // 1
}

得要加个小括号才可以,否则会报错;

数组对应对象属性的解构:


{
let arr = [1, 2, 3];
let { 0 : one, [arr.length-1] : three } = arr;
console.log(one); // 1
console.log(three); // 3
}

3.字符串的解构赋值

字符串也可以解构赋值,因为字符串可以转换成一个类似数组的对象


{
let [a, b, c, d] = 'hero'; console.log(a); //h
console.log(b); //e
console.log(c); //r
console.log(d); //o
}

类似数组的对象都有一个length属性,可以对这个属性解构赋值


{
let { length: len } = 'hero';
console.log(len); // 4
}

4.数值和布尔值的解构赋值

解构赋值时,如果等号右边是数值或者布尔值时,则会先转换成对象


{
let { toString: s } = 123;
console.log(s === Number.prototype.toString); //true
} {
let { toString: s } = true;
console.log(s === Boolean.prototype.toString); //true
}

解构赋值的规则:如果等号右边的值不是对象或者数组则会先转为对象,由于undefined和null无法转为对象,所以无法对它们进行解构赋值,会报错,如下:


{
let { props: x} = undefined; //报错
let { props: y} = null; //报错
}

5.函数参数的解构赋值


{
const arr = [[1,2],[3,4]].map(([a, b])=> a+b);
console.log(arr); //[3,7]
}

函数参数默认值:


function func({x = 0, y = 0} = {}) {
return [x, y];
} console.log(func({x:5,y:6})); //[5,6]
console.log(func({x:5})); //[5,0]
console.log(func({})); //[0, 0]
console.log(func()); //[0, 0]

如果按照以下定义就不同了,如下:


function fn({x, y} = { x: 1, y: 2}) {
return [x, y];
}
console.log(fn({ x: 11, y: 22})); // [11, 22]
console.log(fn({ x: 11 })); // [11, undefined]
console.log(fn({})); // [undefined, undefined]
console.log(fn()); // [1, 2]

undefined会触发函数参数的默认值,如下:


{
const a = [1, undefined, 3].map((x = 'noundefine') => x);
console.log(a); //[1, "noundefine", 3]
}

6.圆括号问题

圆括号只能一种情况才能使用:赋值语句的非模式部分,可以使用圆括号


[(b)] = [3]; // 正确
({ p: (d) } = {}); // 正确
[(parseInt.prop)] = [3]; // 正确

上面三行语句都可以正确执行,因为首先它们都是赋值语句,而不是声明语句;其次它们的圆括号都不属于模式的一部分。第一行语句中,模式是取数组的第一个成员,跟圆括号无关;第二行语句中,模式是p,而不是d;第三行语句与第一行语句的性质一致。

本文参考链接:http://es6.ruanyifeng.com/#do...
主要是看了阮一峰老师的文章,自己整理了一下,供后期自己看笔记用的

来源:https://segmentfault.com/a/1190000017416618

ES6精解:变量的解构赋值的更多相关文章

  1. ES6学习之变量的解构赋值

    前言:什么是ES6?ECMAScript 6(简称ES6)是JavaScript语言的下一代标准,已经在2015年6月正式发布了.其中相比较于ES5新增了诸多的特性,并且ES6可转换为ES5的语法.- ...

  2. JavaScript学习笔记 -- ES6学习(三) 变量的解构赋值

    1.解构赋值的定义 在ES6中,允许按照一定模式,从数组和对象中提取值(所谓解构),然后对变量进行赋值. var a = 1; var b = 2; var c = 3; //等价于 var [a, ...

  3. ES6学习历程(变量的解构赋值)

    一.数组的解构赋值 1.举几个例子足以理解 let [a, b, c] = [1, 2, 3]; a:1;  b:2;  c:3; let [x, , y] = [1, 2, 3];  x:1   y ...

  4. ES6学习4 变量的解构赋值

    变量的解构赋值 一.数组结构赋值 1.数组结构赋值 let [a, b, c] = [1, 2, 3]; ES6 可以从数组中提取值,按照对应位置,对变量赋值. 1)  本质上,这种写法属于“模式匹配 ...

  5. ES6入门之变量的解构赋值(二)

    前言 在上一章 ES6入门之let和const命令中我们对ES6的相关语法已经有了初步了解,上一章中我们主要学习了三大部分的内容,let命令的使用,块级作用域,const命令的使用,那么从本篇博客将进 ...

  6. ES6中的变量的解构赋值, 解放我们的双手,实现变量的批量赋值

    ES6--变量的解构赋值 引言 正文 一.数组的解构赋值 解构失败 不完全解构 默认值 二.对象的解构赋值 三.字符串的解构赋值 结束语 引言 变量的解构赋值, 听起来很复杂, 简单点说可以理解成批量 ...

  7. ES6 学习笔记 - 变量的解构赋值

    变量的解构赋值 学习资料:ECMAScript 6 入门 数组的解构赋值 基本用法 可以从数组中提取值,按照对应位置,对变量赋值.这种写法属于"模式匹配". let [a, b, ...

  8. es6变量声明和解构赋值

    /*声明: * 本文内容多为学习借鉴性内容,大部分非原创 * 特别感谢阮一峰的 ECMAScript6 入门,推荐大家学习 */ 一.es5变量声明的不足 1.变量提升和函数声明提升 es5的代码加载 ...

  9. es6基础入门变量的解构赋值

    let [a, b, c] = [1, 2, 3]; let [foo, [[bar], baz]] = [1, [[2], 3]]; foo bar baz let [ , , third] = [ ...

  10. ES6学习笔记(2)----变量的解构和赋值

    参考书<ECMAScript 6入门>http://es6.ruanyifeng.com/ 变量的解构和赋值 本质上:只要模式匹配,左边的变量就能被赋予右边对应的值 原则: 解构赋值的规则 ...

随机推荐

  1. Ubuntu操作

    1. 从windows 拷贝文件到Ubuntu: scp  /c/Users/init/Downloads/pycharm-community-2019.3.tar.gz      alice@192 ...

  2. 面试题常考&必考之--js中的数组去重和字符串去重

    1.引入:首先得知道数组没有可以直接去重的方法,即直接[].unique()是不支持的, 会报“Uncaught TypeError: [].unique is not a function”错误, ...

  3. es6的扩展运算符

    扩展运算符用三个点号表示,功能是把数组或类数组对象展开成一系列用逗号隔开的值,扩展运算符有几点作用: 一,展开数组 //展开数组 let a = [1,2,3,4,5], b = [...a,6,7] ...

  4. CF704D Captain America

    http://codeforces.com/problemset/problem/704/D 题解 对于两种颜色的染色,我们可以把它看做选择问题. 比如说红色的代价小,所以我们尽可能多的染红色. 然后 ...

  5. Beauty Values

    Beauty Values 题意:给$n$个数, 定义它的Beauty Values为所有连续子区间的(区间长度*区间内不同数字的数目)求和 求Beauty Values A[i]数组表示数字i最近一 ...

  6. [CSP-S模拟测试]:糊涂图(概率DP)

    题目传送门(内部题76) 输入格式 第一行输入三个空格隔开的整数$n,m,s$表示随机加一条边之前的糊涂图的点数,边数,以及起点的编号. 接下来$m$行,每行两个空格隔开的整数$a,b$表示从$a$到 ...

  7. 后端PHP框架laravel学习踩的各种坑

    安装完laravel的ventor目录后出现“Whoops, looks like something went wrong.”这样的错误信息 打开config/app.php,打开debug为tru ...

  8. FCC成都社区·前端周刊 第 2 期

    01. Propel:JS的科学计算框架 Propel 是一种 JavaScript 科学计算框架,类似于 Python 中的科学计算库 NumPy,也就是说利用 JS 也可以进行机器学习啦.Prop ...

  9. functional-page-navigator 组件

    functional-page-navigator 组件:是一个非常强大的组件,用于跳转插件的功能页 functional-page-navigator组件的属性: version:类型 字符串 跳转 ...

  10. vue +ts 在router的路由中import报错的解决方案

    在router.ts中引入.vue文件,会提示打不到module,但是编译可能成功,运行也不报错 找了好久,发现了这个答案 https://segmentfault.com/a/11900000167 ...