一.数组的解构赋值

  1.举几个例子足以理解

  1. let [a, b, c] = [1, 2, 3]; a:1;  b:2;  c:3;

  2. let [x, , y] = [1, 2, 3];  x:1   y:2;

  3. let [foo, [[bar], baz]] = [1, [[2], 3]]; foo:1; bar:2; baz:3;

  4. let [head, ...tail] = [1, 2, 3, 4];head:1;  tail:[2,3,4];

  5. let [a, [b], d] = [1, [2, 3], 4];a:1  b:2  d:4;

二.对象的解构赋值

  1.举几个例子足以理解

    1. let { a, b} = { a: "aaa", b: "bbb" };a:"aaa"  b:"bbb";

    2. let { c } = { a: "aaa", b: "bbb" };c:undefined;

    3. let obj = { p: [ 'Hello', { y: 'World' } ] }; let { p: [x, { y }] } = obj;x:'hello' y:'world';

    4. const node = { loc: { start: { line: 1, column: 5 } } }; let { loc, loc: { start }, loc: { start: { line }} } = node; line // 1 loc // Object {start: Object} start // Object {line: 1, column: 5}

    5. var { message: msg = 'Something went wrong' } = {}; msg // "Something went wrong"(对象的解构赋值也可以设置默认值);默认值生效的条件:对象的属性值严格等于undefined

    6. var {x = 3} = {x: null}; x // null;null 不严格的等于undefined;

    7. // 报错  let {foo: {bar}} = {baz: 'baz'}; foo的值等于undefined;undefined没有bar属性;

    8. // 错误的写法 let x; {x} = {x: 1}; // SyntaxError: syntax error;对于已经声明的值进行解构赋值的时候要格外小心;正确写法({x} = {x: 1});不加小括号的时候,{x}是一个独立的代码块;

    9. 常用的场景:let { log, sin, cos } = Math;

    10. let arr = [1, 2, 3]; let {0 : first, [arr.length - 1] : last} = arr; first // 1 last // 3

三.字符串的解构赋值

  1.仍然举几个例子说事情:

    1. const [a, b, c, d, e] = 'hello'; a // "h" b // "e" c // "l" d // "l" e // "o";

    2. let {length : len} = 'hello'; len // 5; 因为'hello'也有length属性,所以,len==5;

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

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

    1. let {toString: s} = 123; s === Number.prototype.toString // true let {toString: s} = true; s === Boolean.prototype.toString // true;;;;上面代码中,数值和布尔值的包装对象都有toString属性,因此变量s都能取到值。
    2. let { prop: x } = undefined; // TypeError let { prop: y } = null; // TypeError;;;解构赋值的规则是,只要等号右边的值不是对象或数组,就先将其转为对象。由于undefinednull无法转为对象,所以对它们进行解构赋值,都会报错。

五.函数参数的解构赋值

  1.function add([x, y]){ return x + y; } add([1, 2]); // 3

  2.function move({x, y} = { x: 0, y: 0 }) { return [x, y]; } move({x: 3, y: 8}); // [3, 8] move({x: 3}); // [3, undefined] move({}); // [undefined, undefined] move(); // [0, 0];带有默认值的函数;

五.函数参数的解构赋值

  1.圆括号的问题:ES6 的规则是,只要有可能导致解构的歧义,就不得使用圆括号。下列情况均会报错:

    1. 变量的声明不可以使用圆括号;
    2. 函数参数不允许使用圆括号;
    3. 复制语句模式不可以使用圆括号;          

ES6的文档下面还有部分内容,如果感兴趣可以自己再去浏览:变量的解构赋值;

 

ES6学习历程(变量的解构赋值)的更多相关文章

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

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

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

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

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

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

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

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

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

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

  6. ES6 - 基础学习(3): 变量的解构赋值

    解构赋值概述 1.解构赋值是对赋值运算符的扩展. 2.它是一种针对数组或者对象进行模式匹配,然后对其中的变量进行赋值. 3.代码书写上显得简洁且易读,语义更加清晰明了:而且还方便获取复杂对象中的数据字 ...

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

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

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

    1.ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring). 2.ES6允许写成:let [a,b,c] = [1,2,3];上面代码表示,可以从数 ...

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

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

随机推荐

  1. F广搜

    <span style="color:#330099;">/* F - 广搜 基础 Time Limit:1000MS Memory Limit:10000KB 64b ...

  2. 《转》OpenStack对象存储——Swift

    OpenStack Object Storage(Swift)是OpenStack开源云计算项目的子项目之中的一个.被称为对象存储.提供了强大的扩展性.冗余和持久性.本文将从架构.原理和实践等几方面讲 ...

  3. install yael on the ubuntu 12.04

    1. bits/predefs.h no such file or directory  ??? sudo apt-get install gcc-multilib 2. sudo gedit /et ...

  4. 调用线程必须为 STA,因为许多 UI 组件都需要

    WPF中,代码中准备控制控件内容时,有时会报错: 调用线程必须为 STA,因为许多 UI 组件都需要 我知道,在winform下面,使用多线程时,控件的值读取是可以的,但如果要更改,那么就必须进行一些 ...

  5. YTU 2760: 字符串---首字母变大写

    2760: 字符串---首字母变大写 时间限制: 1 Sec  内存限制: 128 MB 提交: 343  解决: 136 题目描述 输入一行英文句子,将每个单词的第一个字母改成大写字母. 输入 一个 ...

  6. Applications(模拟)

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3705 题意:主要是分值计算要注意以下几点: (1) 在MOJ上解出的题,如 ...

  7. [Swift通天遁地]八、媒体与动画-(10)在项目中播放GIF动画

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  8. Android内存管理(11)*常见JVM回收机制「Java进程内存堆分代,JVM分代回收内存,三种垃圾回收器」

    参考: http://www.blogjava.net/rosen/archive/2010/05/21/321575.html 1,Java进程内存堆分代: 典型的JVM根据generation(代 ...

  9. webHttpBinding+wsHttpBinding+basicHttpBinding的区别 (转)

    1. webHttpBinding (web AJAX/JSON)2. wsHttpBinding (ASP.NET client) 3. basicHttpBinding (Silverlight) ...

  10. jQuery五屏轮播手风琴切换代码

    jQuery五屏轮播手风琴切换代码 在线演示本地下载