rest参数与扩展运算符

  1. rest参数

    当遇上这样一种需求:对于输入的参数,求和返回,但传入的参数个数并不确定。

    1. // 在es5中,通常是使用函数自身的arguments对象实现的
    2. function sum () {
    3. let sum = 0;
    4. for(let i = 0; i < arguments.length; i++) {
    5. sum += arguments[i];
    6. }
    7. return sum;
    8. }

    9. // 使用Array.from将其转化为数组,就可以使用数组的方法
    10. function sum () {
    11. // arguments对象是一个伪数组,必须转化为数组才能使用reduce方法
    12. return Array.from(arguments).reduce((temp, value) => temp + value, 0);
    13. }
    14. // 使用Array.prototype.call()方法返回一个数组对象 --> 将伪数组转换为数组
    15. function sum () {
    16. return Array.prototype.call(arguments).reduce((temp, value) => temp +value, 0);
    17. }

    18. // ES6中还可以通过rest参数接收函数参数,并转换成一个数组
    19. function sum (...plus) {
    20. return plus.reduce((temp, value) => temp + value, 0);
    21. }

    注意:rest参数只能作为函数的最后一个参数,否则会报错

    1. function func (a, ...rest, b) {
    2. // do something
    3. }
    4. // Rest Parameter must be last formal paramter
  2. 扩展运算符

    扩展运算符与rest参数恰好是一个逆过程,rest参数是将多个参数转换成一个数组,而运算符扩展则是将一个数组扩展成多个参数的形式。

    1. // 现有一个数组
    2. let arr = [1, 2, 3, 4, 5];
    3. // 有一个求和函数
    4. function sum (...rest) {
    5. return rest.reduce((temp, value) => temp + value, 0);
    6. }
    7. // 现在需要通过sum函数对数组进行求和操作,但是函数需要的参数不是数组
    8. // 在es5中是不容易实现的
    9. // 但是使用扩展运算符,恰好可以解决问题
    10. sum(...arr);
    11. let arr1 = [1, 2, 3, 4, 5];
    12. let arr2 = [6, 7, 8];
    13. // 求arr1和arr2所有元素的和
    14. sum(...arr1, ...arr2);

    扩展运算符还可以用于数组的复制

    1. let arr1 = [1, 2, 3, 4];
    2. // ...arr1 扩展运算符就相当于 1, 2, 3, 4 --> 即数组的展开
    3. let copy = [...arr1];

    对于任何实现了遍历器接口(Iterator)的对象都可以使用扩展运算符

    1. let lis = document.querySelectorAll('li');
    2. console.log(...lis); // <li>a</li> <li>b</li> <li>c</li>
    3. // querySelectorAll()函数返回的是一个NodeList对象(注意:与document.get...系列返回的HTML集合是不一样的)
    4. let lisList = [...lis];
    5. // 内部的...后的参数是一个NodeList对象,NodeList对象实现了遍历器接口,因此能够用扩展运算符进行扩展,而后形成一个新数组,使用该方法可以将伪数组转化为数组

rest参数与扩展运算符的更多相关文章

  1. rest 参数和扩展运算符

    rest 参数和扩展运算符 rest 参数的形式为 ...变量名:扩展运算符是三个点 .... rest 参数 function add(...values) { console.log(values ...

  2. rest 参数与扩展运算符

    rest 参数与扩展运算符 1.rest 参数 ES6 引入 rest 参数(形式为...变量名),用于获取函数的多余参数,这样就不需要使用arguments对象了.rest 参数搭配的变量是一个数组 ...

  3. ES6 rest参数和扩展运算符

    rest参数 ES6引入了rest参数(形式为“…变量名”).其中rest参数搭配的变量是一个数组可以使用数组的一切操作. 例: function rest(...values){ let sum=0 ...

  4. es6 默认参数、rest参数、扩展运算符

    1.默认值 现在可以在定义函数的时候指定参数的默认值了,而不用像以前那样通过逻辑或操作符来达到目的了. function sayHello(name){ //传统的指定默认参数的方式 var name ...

  5. ES6学习笔记(一)——扩展运算符和解构赋值

    前言 随着前端工程化的快速推进,在项目中使用ES6甚至更高的ES7等最近特性早已不是什么新鲜事.之前还觉得既然浏览器支持有限,那了解一下能看懂就好,然而仅仅了解还是不够的,现在放眼望去,那些成熟框架的 ...

  6. es6中参数【默认值,扩展运算符】

    参数默认值 1.普通参数 function info(age,name="grace"){ console.log(name); } info(); //输入:grace 2.对象 ...

  7. es6可变参数-扩展运算符

    es5中参数不确定个数的情况下: //求参数和 function f(){ var a = Array.prototype.slice.call(arguments); var sum = 0; a. ...

  8. ES6躬行记(2)——扩展运算符和剩余参数

    扩展运算符(Spread Operator)和剩余参数(Rest Parameter)的写法相同,都是在变量或字面量之前加三个点(...),并且只能用于包含Symbol.iterator属性的可迭代对 ...

  9. ...扩展运算符+rest参数+call/apply/bind

    之前在set,map里面有提过扩展运算符的概念,但是今天偶然遇到一个问题,类似于扩展运算符的经典用法,突然发现对其了解不是很深,所以再来整理一下扩展运算符的相关知识. 重点:扩展运算符内部调用的是数据 ...

随机推荐

  1. C语言实验一(3)

    #include<stdio.h> #include<math.h> int main() { float x,y; scanf("%f,%f",& ...

  2. python操作mysql——mysql.connector

    连接mysql, 需要mysql connector, conntector是一种驱动程序,python连接mysql的驱动程序,mysql官方给出的名称为connector/python, 可参考m ...

  3. 一个简单的对任意list分页的工具-----PageUtil

    一.工具类代码 1 import java.util.List; 2 import java.util.stream.Collectors; 3 4 public class PageUtil< ...

  4. SQL Server 创建索引方法

    转自 <SQL Server 创建索引的 5 种方法> 地址:https://www.cnblogs.com/JiangLe/p/4007091.html 前期准备: create tab ...

  5. css3 翻牌动画

    最近做了一个特效,css是从网上找的,地址是这个: CSS3 animate flip下的纸牌翻转效果实例页面 把其中核心的css代码扒出来如下: /* The properties in this ...

  6. JS数组映射保存数据-场景

    开发遇到,写个随笔,以防我的金鱼记忆 场景:一个页面从后台拿到20条数据,把他们展现在页面上,当点击某一个item时,需要展示这个item的详情,通常不会去把页面调走,就在本页面通过 display: ...

  7. centos 日志文件

    以下介绍的是20个位于/var/log/ 目录之下的日志文件.其中一些只有特定版本采用,如dpkg.log只能在基于Debian的系统中看到./var/log/messages — 包括整体系统信息, ...

  8. Eclipse在线集成SpringBoot

    在线集成下载地址:http://dist.springsource.com/release/TOOLS/update/e4.8/ 注意:需要更改后面的版本号,跟随自己eclipse版本号下载,只需要改 ...

  9. c++面试题一

    c++面试题 1.是不是一个父类写了一个virtual函数,如果子类覆盖他的函数不加virtual, 也能实现多态? virtual 修饰符会被隐形继承的. private也被集成,只事派生类没有访问 ...

  10. 等积投影(equal-area projection)

    等积投影(equal-area projection)是地图投影的一种,是地图上任何图形面积经主比例尺放大以后与实地上相应图形面积保持大小不变的一类投影.即投影面积与实地面积相等的投影——面积比为1. ...