文章目录

  • 扩展运算符
  • 应用

扩展运算符

扩展运算符(…)作用是将一个数组转为用逗号分隔的参数序列。

console.log(...[1, 2, 3]);  // 1 2 3console.log(1, ...[2, 3]);  // 1 2 3

该运算符主要用于函数调用:

function _push(arr, ...items) { // 这里的 ...items 将会以数组的形式接收所有剩余的参数console.log(items);  // [2, 3]arr.push(...items);
}_push([1], 2, 3]);  // [1, 2, 3]

如果该运算符后面是一个空数组,则不产生任何效果:

console.log(...[]);  // 空
console.log([...[], 1]);  // [1]

应用

1️⃣ 求数组最大与最小元素

// ES5
Math.max.apply(null, arr);// ES6
Math.max(...arr);

2️⃣ 将一个数组添加到另一个数组的尾部

// ES5
Array.prototype.push.apply(arr1, arr2);// ES6
arr1.push(...arr2);

3️⃣ 复制数组

// ES5
const arr2 = arr1.concat();// ES6
const arr2 = [...arr1];
// 写法二
const [...arr2] = arr1

4️⃣ 合并数组

// ES5
arr1.concat(arr2, arr3);// ES6
[...arr1, ...arr2, ...arr3];

5️⃣ 与解构赋值结合

const [first, ...rest] = [1, 2, 3];
first // 1
rest  // [2, 3]const [first, ...rest] = [];
first // undefined
rest  // []

如果将扩展运算符用于数组赋值时,只能放在参数的最后一位,否则报错:

const [...rest, last] = [1, 2, 3];   // 报错

6️⃣ 字符串

扩展运算符可以将字符串转为真正的数组:

[...'hello'];  // ['h', 'e', 'l', 'l', 'o']

7️⃣ 定义了遍历器(Iterator)接口的对象,都可以用扩展运算符转为真正的数组。

let nodeList = document.querySelectAll('div');
let arr = [...nodeList];

对于那些没有部署 Iterator 接口的类似数组的对象,扩展运算符就无法将其转为真正的数组。

let arrayLike = {'0': 'a','1': 'b','2': 'c',length: 3
};// TypeError: Cannot spread non-iterable object.
let arr = [...arrayLike];

参考文章

ES6 数组的扩展:扩展运算符相关推荐

  1. ES6 数组、对象的扩展

    8. 数组的扩展 扩展运算符(...),将一个数组转为用逗号分隔的参数序列. 复制数组 const a2=[...a1] 合并数组 [...arr1, ...arr2, ...arr3]; arr1. ...

  2. 【JavaScript】ES6 数组的扩展

    ES5 数组基础 ES5 数组常用方法 ES5 数组方法 arr.forEach() arr.forEach(callback[, thisObj]) 简单地遍历数组 callback:回调函数,没有 ...

  3. ES6基础3(扩展)-学习笔记

    文章目录 ES6基础3(扩展)-学习笔记 字符串扩展 数值扩展 函数扩展 扩展运算符 ES6基础3(扩展)-学习笔记 字符串扩展 //扩展//字符串扩展charAt(); //返回指定索引位置的字符 ...

  4. ES6学习笔记(五):轻松了解ES6的内置扩展对象

    前面分享了四篇有关ES6相关的技术,如想了解更多,可以查看以下连接 <ES6学习笔记(一):轻松搞懂面向对象编程.类和对象> <ES6学习笔记(二):教你玩转类的继承和类的对象> ...

  5. es6调用c语言sdk,ES6 关于对象的扩展-contracts-WinFrom控件库|.net开源控件库|HZHControls官网...

    今天来简单说下ES6 中对象的扩展 首先回顾传统的对象表示法 let person={ 'name':'zhang', 'age':'20', 'play':function(){ alert('pl ...

  6. es6 内置对象扩展rest, Arry 扩展方法Array.from(),find(), findIndex(),includes()

    1.es6内置对象扩展rest实参 2.  Arry 扩展方法    (1)构造函数方法:Array.from()   (2) find()   (3) findIndex()   (4)includ ...

  7. 数组超过预设的最大数组大小_工作表数组大小的扩展及意义

    朋友们好,今日给大家继续讲解VBA数组与字典解决方案的第17讲,数组大小的扩充问题.这一讲的内容相对比较简单,在之前的章节中讲了数组与数组的计算规律,也是利用了数组的扩展原理. 其实,两个数组计算时, ...

  8. es6 数组合并_13个不low的JS数组操作,你需要知道一下

    作者 | 火狼1来源 | https://juejin.im/post/5c92e385e51d450ce11df1d1 前言 本文主要从应用来讲数组api的一些骚操作:如一行代码扁平化n维数组.数组 ...

  9. es6 数组合并_那些会用到的 ES6 精粹(包邮送书)

    前言 最新的 ECMAScript 都已经到发布到 2019 版了. 我们应该有的态度是:Stay hungry ! Stay young ! 从接触 vue 到工作中用到 vue 将近 2 年了,在 ...

  10. ES6数组去重的三个简单办法

    ES6数组去重的三个简单办法 简单说一下利用ES6实现数组去重的三个办法. 第一种: 利用Map对象和数组的filter方法 贴上相关代码 打印后的结果 通过打印我们发现,确实实现了我们想要的效果.那 ...

最新文章

  1. PDAL点云处理库介绍
  2. 虚拟化厂商VMware、微软和思杰的vGPU支持概述
  3. 谷歌浏览器linux版_Chrome apps 要被谷歌干掉了
  4. 使用Unified Auditing Policy审计数据泵导出操作
  5. Project Server的页面如何修改Text
  6. The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone
  7. MySQL高级 - MyISAM特性
  8. 【转】解密Qt安装目录的结构
  9. 如何理解马尔可夫决策过程?
  10. android网络游戏开发实战pdf_python爬虫开发与项目实战PDF高清文档下载
  11. 2016年3月19日 培训复习
  12. 移动端微信、QQ、浏览器调用qq临时会话功能
  13. unity 获取屏幕角坐标_Unity3D世界坐标与屏幕坐标
  14. 波特率和比特率之间的关系
  15. 论文公式居中编号右对齐方式
  16. 网络分析仪自动化测试软件,高效矢量网络分析仪自动测试方法
  17. C#使用iTextSharp给PDF文件添加水印,PDF文件加密,PDF文件旋转
  18. 特征工程——特征选择
  19. 宝塔提示PHP7.3等版本无zip扩展解决
  20. 土地覆盖/土地利用简介及数据集

热门文章

  1. vue获取屏幕高度并赋值给盒子
  2. 去癌-计算模拟-分子动力学-01
  3. wincc上位机与1200组态步骤_博途v13的wincc能组态上位机吗
  4. 色差仪的工作原理和使用方法
  5. OpenCV中imshow函数的使用
  6. 在c语言中sqrt如何用,sqrt在c语言中怎么用?
  7. 淘宝/天猫API:item_search_best-天猫畅销榜
  8. 华为OD机试题,用 Java 解【火星文计算 2】问题
  9. windows10使用本地安全策略只允许某些ip访问远程计算机
  10. plt、np、pd、talib、scipy、sklearn常用API总结