问答题725/1593说说对 ES6 中rest参数的理解

难度:
2022-04-10 创建

参考答案:

ES6 引入 rest 参数(形式为...变量名),用于获取函数的多余参数,这样就不需要使用arguments对象了。rest 参数搭配的变量是一个数组,该变量将多余的参数放入数组中。

1function add(...values) { 2 let sum = 0; 3 4 for (var val of values) { 5 sum += val; 6 } 7 8 return sum; 9} 10 11add(2, 5, 3) // 10

上面代码的add函数是一个求和函数,利用 rest 参数,可以向该函数传入任意数目的参数。

下面是一个 rest 参数代替arguments变量的例子。

1// arguments变量的写法 2function sortNumbers() { 3 return Array.prototype.slice.call(arguments).sort(); 4} 5 6// rest参数的写法 7const sortNumbers = (...numbers) => numbers.sort();

上面代码的两种写法,比较后可以发现,rest 参数的写法更自然也更简洁。

arguments对象不是数组,而是一个类似数组的对象。所以为了使用数组的方法,必须使用Array.prototype.slice.call先将其转为数组。rest 参数就不存在这个问题,它就是一个真正的数组,数组特有的方法都可以使用。下面是一个利用 rest 参数改写数组push方法的例子。

1function push(array, ...items) { 2 items.forEach(function(item) { 3 array.push(item); 4 console.log(item); 5 }); 6} 7 8var a = []; 9push(a, 1, 2, 3)

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

1// 报错 2function f(a, ...b, c) { 3 // ... 4}

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

1(function(a) {}).length // 1 2(function(...a) {}).length // 0 3(function(a, ...b) {}).length // 1

箭头函数不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替

最近更新时间:2024-07-22

赞赏支持

预览

题库维护不易,您的支持就是我们最大的动力!