如何使用es6函数之rest参数
这篇文章主要讲解了如何使用es6函数之rest参数,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
es6引入rest参数(形式为 …变量名),用于获取函数的多余参数,这样就不需要使用arguments对象了,rest参数搭配的变量是一个数组,该变量将多余的参数放入数组中。
function add (...values) { let sum = 0; for (var val of values) { sum += val } return sum}add(2, 3, 5) // 10
上面代码的add函数是一个求和函数,利用rest参数,可以向该函数传入任意数目的参数。
下面是一个rest参数代替arguments变量的例子。
// arguments变量的写法function sortNumbers() { return Array.prototype.slice.call(arguments).sort()}// rest参数的写法const sortNumbers = (...numbers) => numbers.sort()
上面代码的两种写法,比较后可以发现,rest参数的写法更自然也更简洁。
arguments对象不是数组,而是一个类似数组的对象。所以为了使用数组的方法,必须使用Array.prototype.slice.call先将其转为数组。rest参数就不存在这个问题,它就是一个真正的数组,数组特有的方法都可以使用。下面是一个利用rest参数改写数组push方法的例子。
function push(array, ...items) { items.forEach(item => { array.push(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
看完上述内容,是不是对如何使用es6函数之rest参数有进一步的了解,如果还想学习更多内容,欢迎关注亿速云行业资讯频道。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。