37 lines
1.2 KiB
Markdown
37 lines
1.2 KiB
Markdown
---
|
||
title: Rest Parameters
|
||
localeTitle: 休息参数
|
||
---
|
||
## 休息参数
|
||
|
||
在ES6中,其余的参数语法`...`允许您将无限数量的参数收集到数组中。
|
||
|
||
尽管它们看起来相同,但它与扩展运算符相反,后者从迭代中获取每个项目并将它们分散到各自的值中。
|
||
|
||
### 句法
|
||
|
||
```js
|
||
function myFunc(...args) {
|
||
console.log(args);
|
||
}
|
||
|
||
myFunc( 1, 2, 3, 4, 5); // [1,2,3,4,5]
|
||
```
|
||
|
||
你可以在它前面加上函数的最后一个参数与`...`当你想要做的初始paramters的东西,然后把所有剩下的参数不同。
|
||
|
||
```js
|
||
function convertCurrency(rate, fee, ...amounts) {
|
||
return amounts.map(amount => (amount * rate) + fee);
|
||
}
|
||
|
||
convertCurrency(0.89, 2.5, 100, 250, 75, 150, 300); // [ 91.5, 225, 69.25, 136, 269.5 ]
|
||
```
|
||
|
||
`...`允许您将其余参数(如果有的话)收集到数组中。
|
||
|
||
### rest参数和arguments对象之间的区别
|
||
|
||
`arguments`是一个类似于数组的对象,在函数内部可用,包含传递给这些函数的参数。它被称为“类似数组”,因为它没有所有数组的内置方法,例如`.forEach()`和`.map()` 。
|
||
|
||
其余参数是一个数组,包含所有数组方法。 |