为了账号安全,请及时绑定邮箱和手机立即绑定

ES6中rest参数详细讲解

标签:
JavaScript

(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


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消