您的位置:首页 > 其它

函数的扩展---rest参数

2018-03-08 16:29 435 查看
ES6 引入 rest 参数(形式为
...变量名
),用于获取函数的多余参数,这样就不需要使用
arguments
对象了。rest 参数搭配的变量是一个数组,该变量将多余的参数放入数组中。function add(...values) {
let sum = 0;

for (var val of values) {
sum += val;
}

return sum;
}

add(2, 5, 3) // 10上面代码的
add
函数是一个求和函数,利用 rest 参数,可以向该函数传入任意数目的参数。下面是一个 rest 参数代替
arguments
变量的例子。
// arguments变量的写法
function sortNumbers() {
return Array.prototype.slice.call(arguments).sort();
}

// rest参数的写法
const sortNumbers = (...numbers) => numbers.sort();
arguments
对象不是数组,而是一个类似数组的对象。所以为了使用数组的方法,必须使用
Array.prototype.slice.call
先将其转为数组。rest 参数就不存在这个问题,它就是一个真正的数组,数组特有的方法都可以使用。下面是一个利用 rest 参数改写数组
push
方法的例子。function push(array, ...items) {
items.forEach(function(item) {
array.push(item);
console.log(item);
});
}

var a = [];
push(a, 1, 2, 3)注意,rest 参数之后不能再有其他参数(即只能是最后一个参数),否则会报错。// 报错
function f(a, ...b, c) {
// ...
}函数的
length
属性,不包括 rest 参数。(function(a) {}).length // 1
(function(...a) {}).length // 0
(function(a, ...b) {}).length // 1
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: