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   // 

(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 (第四值没有与之对应的变量名

你可能感兴趣的:(前端)