js展开语法和剩余参数

展开语法:

函数调用:
myFunction(...iterableObj);

字面量数组构造或字符串:
[...iterableObj, '4', ...'hello', 6];

构造字面量对象时,进行克隆或者属性拷贝(ECMAScript 2018规范新增特性):
let objClone = { ...obj };

执行的是浅拷贝

剩余参数:

语法:
function(a, b, ...theArgs) {
// ...
}

[剩余参数arguments对象的区别]

剩余参数和 [arguments]对象之间的区别主要有三个:

  • 剩余参数只包含那些没有对应形参的实参,而 arguments 对象包含了传给函数的所有实参。
  • arguments对象不是一个真正的数组,而剩余参数是真正的 [Array]实例,也就是说你能够在它上面直接使用所有的数组方法,比如 [sort][map][pop]
  • arguments对象还有一些附加的属性 (如callee属性)。

你可能感兴趣的:(js展开语法和剩余参数)