栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

ES6中rest参数详细讲解

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

ES6中rest参数详细讲解

(1) Rest 参数接受函数的多余参数,组成一个数组,放在形参的最后,形式如下:
function func(a, b, ...theArgs){    // ...}
(2) Rest参数和arguments对象的区别:
  • rest参数只包括那些没有给出名称的参数,arguments包含所有参数

  • arguments 对象不是真正的数组,而rest 参数是数组实例,可以直接应用sort, map, forEach, pop等方法

  • arguments 对象拥有一些自己额外的功能

(3) 从 arguments 转向数组

Rest 参数简化了使用 arguments 获取多余参数的方法

// arguments 方法function func(a, b){    var args = Array.prototype.slice.call(arguments);    console.log(args)
}

func(1,2)// Rest 方法function func(a, b, ...args){    // ...}

注意,rest 参数之后不能再有其他参数(即,只能是最后一个参数),否则会报错

function func(a, ...b, c) {    // ...}// Rest parameter must be last formal parameter

函数的 length 属性,不包括rest参数

(function(a) {}).length     // 1(function(...a) {}).length      // 0(function(a, b, ...c)).length   // 2
(4) Rest参数可以被结构(通俗一点,将rest参数的数据解析后一一对应)不要忘记参数用[]括起来,因为它是数组
function f(...[a, b, c]) {  
  return a + b + c;  
}  
  
f(1)          //NaN 因为只传递一个值,其实需要三个值  f(1, 2, 3)    // 6  f(1, 2, 3, 4) // 6 (第四值没有与之对应的变量名)




转载:https://www.jianshu.com/p/50bcb376a419


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/245462.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号