首页 >> js开发 >> jses6函数之rest参数用法实例分析js大全
jses6函数之rest参数用法实例分析js大全
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
本文实例讲述了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
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()
// 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)
function push(array, ...items) {
items.forEach(item => {
array.push(item)
})
}
var a = []
push(a, 1, 2, 3)
注意,rest参数之后不能再有其他参数(即只能是最后一个参数),否则会报错
function f (a, ...b, c) {
// ..
} // 报错
function f (a, ...b, c) {
// ..
} // 报错
函数的length属性,不包括rest参数。
(function (a) {}).length // 1
(function (...a) {}).length // 0
(function (a, ...b) {}).length // 1
(function (a) {}).length // 1
(function (...a) {}).length // 0
(function (a, ...b) {}).length // 1
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools./code/HtmlJsRun测试上述代码运行效果。在线HTML/CSS/JavaScript代码运行工具在线HTML/CSS/JavaScript代码运行工具http://tools./code/HtmlJsRun关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》JavaScript常用函数技巧汇总javascript面向对象入门教程JavaScript错误与调试技巧总结JavaScript数据结构与算法技巧总结JavaScript数学运算用法总结希望本文所述对大家JavaScript程序设计有所帮助。
function add (...values) {
let sum = 0;
for (var val of values) {
sum += val
}
return sum
}
add(2, 3, 5) // 10
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()
// 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)
function push(array, ...items) {
items.forEach(item => {
array.push(item)
})
}
var a = []
push(a, 1, 2, 3)
注意,rest参数之后不能再有其他参数(即只能是最后一个参数),否则会报错
function f (a, ...b, c) {
// ..
} // 报错
function f (a, ...b, c) {
// ..
} // 报错
函数的length属性,不包括rest参数。
(function (a) {}).length // 1
(function (...a) {}).length // 0
(function (a, ...b) {}).length // 1
(function (a) {}).length // 1
(function (...a) {}).length // 0
(function (a, ...b) {}).length // 1
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools./code/HtmlJsRun测试上述代码运行效果。在线HTML/CSS/JavaScript代码运行工具在线HTML/CSS/JavaScript代码运行工具http://tools./code/HtmlJsRun关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》JavaScript常用函数技巧汇总javascript面向对象入门教程JavaScript错误与调试技巧总结JavaScript数据结构与算法技巧总结JavaScript数学运算用法总结希望本文所述对大家JavaScript程序设计有所帮助。
相关文章:
- jsvue 弹出遮罩层样式实例js大全
- js详解微信小程序入门从这里出发(登录注册、开发工具、文件及结构介绍)js大全
- js解决Vue中的生命周期beforeDestory不触发的问题js大全
- jsvue中解决拖拽改变存在iframe的div大小时卡顿问题js大全
- jsvue中destroyed方法的使用说明js大全
- js在vue中created、mounted等方法使用小结js大全
- jseslint+prettier统一代码风格的实现方法js大全
- js解决Vue router-link绑定事件不生效的问题js大全
- jsvue 清空input标签 中file的值操作js大全
- js解决vue的touchStart事件及click事件冲突问题js大全