美文网首页
简单叙述ES6的简单特性3

简单叙述ES6的简单特性3

作者: 崔泽宇 | 来源:发表于2017-07-18 22:02 被阅读0次

简单叙述ES6的简单特性2

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

es5                   es6
let a = 1;            let [a, b, c] = [1, 2, 3];
let b = 2;
let c = 3;
 上面代码表示,可以从数组中提取值,按照对应位置,对变量赋值
本质上,这种写法属于“模式匹配”,只要等号两边的模式相同,左边的变量就会被赋予对应的值。下面是一些使用嵌套数组进行解构的例子。
let [foo, [[bar], baz]] = [1, [[2], 3]];
foo // 1
bar // 2
baz // 3

let [ , , third] = ["foo", "bar", "baz"];
third // "baz"

let [x, , y] = [1, 2, 3];
x // 1
y // 3

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

let [x, y, ...z] = ['a'];
x // "a"
y // undefined
z // []
如果解构不成功,变量的值就等于undefined。
另一种情况是不完全解构,即等号左边的模式,只匹配一部分的等号右边的数组。这种情况下,解构依然可以成功。
let [x, y] = [1, 2, 3];
x // 1
y // 2

let [a, [b], d] = [1, [2, 3], 4];
a // 1
b // 2
d // 4
上面两个例子,都属于不完全解构,但是可以成功
如果等号的右边不是数组(或者严格地说,不是可遍历的结构,参见《Iterator》一章),那么将会报错。
// 报错
let [foo] = 1;
let [foo] = false;
let [foo] = NaN;
let [foo] = undefined;
let [foo] = null;
let [foo] = {};
对于 Set 结构,也可以使用数组的解构赋值
let [x, y, z] = new Set(['a', 'b', 'c']);
x // "a"
事实上,只要某种数据结构具有 Iterator 接口,都可以采用数组形式的解构赋值
function* fibs() {
  let a = 0;
  let b = 1;
  while (true) {
    yield a;
    [a, b] = [b, a + b];
  }
}

let [first, second, third, fourth, fifth, sixth] = fibs();
sixth // 5

最后这一块代码 我也不是很懂 请教各位大神

相关文章

  • 简单叙述ES6的简单特性3

    简单叙述ES6的简单特性2 ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构 本质上,...

  • 简单叙述ES6的简单特性

    ES6的出现,无疑是给前段开发人员带来新的surprise,它包含了一些很棒的新特性,可以更加简单快捷的实现很多复...

  • 简单叙述ES6的简单特性2

    const 还有另一个用于声明块作用域变量的方法。使用const,你可以声明一个值的只读引用。必须直接给一个变量赋...

  • ES6新特性简单学习记录

    学习文章转自:ES6简单特性学习记录 变量定义新方式:let/const let特性 : 块级作用域(一对{}包括...

  • js 扁平多维数组

    1 递归写法 2 es6 语法 3 最简单的办法

  • es6中有新意的特性

    说起es6大家都很熟悉,有些es6新特性chrome等高级浏览器已经实现,不用我们去编译了。今天我简单说下es6的...

  • Week 4-1

    determinant 行列式 3× 3 矩阵 N × N 矩阵 Laplace expansion, 简单不叙述...

  • Android MVP简单叙述

    V:大哥,那个程序员想让我显示对话框咋整啊?P:没事,我有你的接口对象,实现了方法,你拿去用就是。V:那我里面的数...

  • mapreduce原理简单叙述

    概述 mapreduce简介 master运作 worker运作 从mapreduce看分布式程序 本文假设读者对...

  • MongoDB索引简单叙述

    如何正确使用索引 前言 索引的创建是为了查询的更有效率,更加快速。但索引创建的不合理也会影响查询性能,以及过多的索...

网友评论

      本文标题:简单叙述ES6的简单特性3

      本文链接:https://www.haomeiwen.com/subject/uqqkkxtx.html