展开操作符(spread)

展开运算符(spread operator)允许一个表达式在某处展开。展开运算符在多个参数(用于函数调用)或多个元素(用于数组字面量)或者多个变量(用于解构赋值)的地方可以使用。

函数调用中使用展开运算符

在以前我们会使用apply方法来将一个数组展开成多个参数:

function test(a, b, c) {
console.log(a, b, c) // 输出 0 1 2
}
var args = [0, 1, 2]
test.apply(null, args)

上面代码块中,我们把args数组当作实参传递给了a,b,c,这边正是利用了Function.prototype.apply的特性。

不过ES6有了展开运算符,我们就可以更加简洁地来传递数组参数:

function test(a, b, c) {
console.log(a, b, c) // 输出 0 1 2
}
var args = [0, 1, 2] test(...args)

我们使用...xxx展开运算符就可以把args展开直接传递给test()函数

数组字面量中使用展开运算符

  • 在ES6中,我们可以直接将一个数组合并到另一个数组中
let arr1 = ['a', 'b', 'c']
let arr2 = [...arr1, 'd', 'e'] console.log(arr2) // 输出:["a", "b", "c", "d", "e"]
  • 展开运算符也可以用在push函数中,以后不需再用apply()函数来合并两个数组
let arr1=['a', 'b', 'c']
let arr2=['d', 'e']
arr2.push(...arr1)
console.log(arr2) // 输出:["d", "e", "a", "b", "c"]

用于解构赋值(rest)

  • 解构赋值也是ES6中的一个特性,而展开运算符可以用于部分情景
let [arg1, arg2, ...arg3] = [1, 2, 3, 4]
console.log(arg1) //
console.log(arg2) //
console.log(arg3) // [3, 4]
注意点:
  • 展开运算符在解构赋值中的作用跟上面的展开作用看上去是相反的,它是将多个元素合成了一个新数组。
  • 解构赋值中展开运算符只能用在最后面,不能用在其他的位置
  • 下面的用法就会报语法错误
let [arg1, ...arg2, arg3] = [1, 2, 3, 4]
console.log(arg1)
console.log(arg2)
console.log(arg3)

类数组对象变成数组

  • 展开运算符可以将一个类数组对象变成一个真正的数组对象
let list = document.getElementsByTagName('div')
let arr = [...list]
console.log(arr)
  • list是类数组对象,通过使用展开运算符将其变成了数组对象

对象展开运算符(ES7)

  • ES7中的对象展开运算符可以更快捷地操作对象
let {x, y, ...z} = {x: 1, y: 2, a: 3, b: 4}
console.log(x) //
console.log(y) //
console.log(z) // {a: 3, b: 4}
  • 如上面的代码块,我们可以将一个对象中的一部分抽取出来,成为一个新对象赋值给展开运算符
  • 我们也可以像数组中插入数组那样将一个对象插入到另外一个对象中
let z = {a: 3, b: 4}
let n = {x: 1, y: 2, ...z}
console.log(n) // {x: 1, y: 2, a: 3, b: 4}
  • 合并两个对象
let a = {x: 1, y: 2}
let b = {z: 3}
let c = {...a, ...b}
console.log(c) // {x: 1, y: 2, z: 3}

剩余操作符(rest)

  • rest操作符用在函数的参数内,将剩余的参数放到foods数组中
function breakfast(dessert, drink, ...foods) {
console.log(dessert) //

ES5与ES6常用语法教程之 ④展开运算符...在数组和对象中的作用的更多相关文章

  1. ES5与ES6常用语法教程之 ②解构语法糖、声明变量异同

    js常用语法系列教程如下 es5与es6常用语法教程(1) es5与es6常用语法教程(2) es5与es6常用语法教程(3) es5与es6常用语法教程(4) es5与es6常用语法教程(5) es ...

  2. ES5与ES6常用语法教程之 ③模板字符串、判断字符串是否包含其它字符串

    这部分教程我们主要讲解以下几个常用语法 模板字符串 带标签的模板字符串 判断字符串中是否包含其他字符串 给函数设置默认值 模板字符串 老式的拼接字符串方法 let dessert = '

  3. ES5与ES6常用语法教程之 ①函数写法、创建对象、导入导出模块方式

    函数写法区别 计算a, b两个数字之和,有返回值 es5 写法 function add(a, b) { return a + b; } es6 写法(箭头函数) let add = (a, b) = ...

  4. ES6常用语法简介import export

    ES6常用语法简介import export let与var用法区别 //var var a = []; for (var i = 0; i < 10; i++) { a[i] = functi ...

  5. ES6常用语法

    ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准.因为当前版本的ES6是在2015年发布的,所以又称ECMAScript 2015. 也就是说,ES6就是ES2015. ...

  6. ES6常用语法(上)

    ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,已经在 2015 年 6 月正式发布了.它的目标,是使得 JavaScript 语言可以用来编写复杂的大型应 ...

  7. ES6常用语法总结

    ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准.因为当前版本的ES6是在2015年发布的,所以又称ECMAScript 2015.也就是说,ES6就是ES2015.虽 ...

  8. ES6常用语法(二)

    arrow functions (箭头函数) 函数的快捷写法.不需要 function 关键字来创建函数,省略 return 关键字,继承当前上下文的 this 关键字 // ES5 var arr1 ...

  9. vue学习(一)ES6常用语法

    1 ES6常用语法 1.1 变量提升 例① # 变量提升 <div id="app"> </div> <script> console.log( ...

随机推荐

  1. Eclipse快捷方式早知道!Productive Workflow不再是问题

    MyEclipse CI 2019.4.0安装包下载 本文将为大家介绍Eclipse快捷方式列表,希望可以帮助您提供工作效率.快捷方式主要分以下几个区域: 导航 通用编辑 Java编辑器 插件开发 工 ...

  2. 【Python之路】特别篇--property()函数 和 @property 装饰符

    Python中有一个被称为属性函数(property)的小概念,它可以做一些有用的事情.在这篇文章中,我们将看到如何能做以下几点: 将方法转换为只读属性 重新实现一个属性的setter和getter方 ...

  3. vue 运行脚手架报错

    报错: You are using the runtime-only build of Vue where the template compiler is not available. Either ...

  4. 关于windows 设备驱动重要的事实

    1. windows采用设备树描述所有挂在系统总线上的设备,每个设备对应一个节点. 2.每个设备有自己的device object stack/driver stack. 一个物理上的设备对应多个de ...

  5. Node.js 安装与开发

    Node.js 简介 Node.js是一个Javascript运行环境(runtime),发布于2009年5月,由Ryan Dahl开发,实质是对Chrome V8引擎进行了封装.Node.js对一些 ...

  6. Ansible常用模块之命令类模块

    Command模块 在远程节点上执行命令 [root@tiandong ~]# ansible all -m command -a "ls" 在远程主机上执行ls命令. [root ...

  7. R-三次指数平滑法实践

    data <- read.csv("H://day_shuaka.csv") raw0 <- data[359:752,] raw0$weekday <- as. ...

  8. triplet

    询问次数<=min(2*n,n+35) 一种类似hash的交互题 部分分n=5,限制10次 发现都问出来可以通过次数和大小确定所有的值和对应位置! n比较大 发现(X1,X2,i)能确定一些情况 ...

  9. oracle取出所有表和视图

    select c.TABLE_NAME, d.COMMENTS, d.table_type, (select wmsys.wm_concat(a.column_name) from user_cons ...

  10. OSI的七层模型和TCP/IP的五层模型

    OSI七层模型: 应用层->表示层->会话层->传输层->网络层->数据链路层->物理层 TCP/IP五层模型: 应用层->传输层->网络层->数 ...