时间:2021-05-28
本文实例讲述了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感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言本文主要给大家介绍了关于ES6中rest参数与扩展运算符的相关内容,rest参数和扩展运算符都是ES6新增的特性。rest参数的形式为:...变量名;扩展运
本文实例讲述了es6函数之严格模式用法。分享给大家供大家参考,具体如下:从es5开始,函数内部可以设定为严格模式。functiondoSomething(a,b
本文实例讲述了ES6知识点整理之函数数组参数的默认值及其解构应用。分享给大家供大家参考,具体如下:在ES6中,函数的参数也可以使用解构赋值和默认值的设置,下面我
本文实例讲述了ES6新特性之函数的扩展。分享给大家供大家参考,具体如下:一、函数参数默认值1.ES6允许为函数的参数设置默认值,即直接写在参数定义的后面。fun
本文实例讲述了ES6新特性之Symbol类型用法。分享给大家供大家参考,具体如下:Symbol类型1.为了避免属性名的冲突,ES6新增了Symbol类型。Sym