es6函数之rest参数用法实例分析


Posted in Javascript onApril 18, 2020

本文实例讲述了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.3water.com/code/HtmlJsRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
js 禁止选择功能实现代码(兼容IE/Firefox)
Apr 23 Javascript
基于jQuery实现的当离开页面时出现提示的实现代码
Jun 27 Javascript
js图片延迟技术一般的思路与示例
Mar 20 Javascript
js数组的基本操作(很全自己整理的)
Oct 16 Javascript
JS实现slide文字框缩放伸展效果代码
Nov 05 Javascript
js指定步长实现单方向匀速运动
Jul 17 Javascript
Vue2.0基于vue-cli+webpack父子组件通信(实例讲解)
Sep 14 Javascript
javascript实现Emrips反质数枚举的示例代码
Dec 06 Javascript
vue-router传参用法详解
Jan 19 Javascript
vue.js实现图书管理功能
Sep 24 Javascript
JavaScript中Object、map、weakmap的区别分析
Dec 15 Javascript
Vue图片裁剪组件实例代码
Jul 02 Vue.js
vue实现短信验证码输入框
Apr 17 #Javascript
JS监听组合按键思路及实现过程
Apr 17 #Javascript
javascript canvas检测小球碰撞
Apr 17 #Javascript
Vue实现浏览器打印功能的代码
Apr 17 #Javascript
基于JavaScript获取url参数2种方法
Apr 17 #Javascript
VSCode写vue项目一键生成.vue模版,修改定义其他模板的方法
Apr 17 #Javascript
vue fetch中的.then()的正确使用方法
Apr 17 #Javascript
You might like
ThinkPHP框架设计及扩展详解
2014/11/25 PHP
PHP实现格式化文件数据大小显示的方法
2015/01/03 PHP
Yii2语言国际化的配置教程
2018/08/19 PHP
Thinkphp整合阿里云OSS图片上传实例代码
2019/04/28 PHP
php设计模式之策略模式应用案例详解
2019/06/17 PHP
PHP Redis扩展无法加载的问题解决方法
2019/08/22 PHP
Javascript 继承机制实例
2009/08/12 Javascript
利用javascript的面向对象的特性实现限制试用期
2011/08/04 Javascript
javascript间隔刷新的简单实例
2013/11/14 Javascript
利用了jquery的ajax实现二级联互动菜单
2013/12/02 Javascript
javascript中使用正则计算中文长度的例子
2014/04/29 Javascript
JavaScript简介
2015/02/15 Javascript
SpringMVC restful 注解之@RequestBody进行json与object转换
2015/12/10 Javascript
JS简单循环遍历json数组的方法
2016/04/22 Javascript
jQuery中通过ajax调用webservice传递数组参数的问题实例详解
2016/05/20 Javascript
JavaScript实现打开链接页面的方式汇总
2016/06/02 Javascript
PHP获取当前页面完整URL的方法
2016/12/02 Javascript
详解JavaScript中的函数、对象
2019/04/01 Javascript
Vue结合路由配置递归实现菜单栏功能
2020/06/16 Javascript
关于vue 结合原生js 解决echarts resize问题
2020/07/26 Javascript
原生JS生成指定位数的验证码
2020/10/28 Javascript
python实现登陆知乎获得个人收藏并保存为word文件
2015/03/16 Python
python计算时间差的方法
2015/05/20 Python
Python 常用 PEP8 编码规范详解
2017/01/22 Python
一篇文章读懂Python赋值与拷贝
2018/04/19 Python
python Qt5实现窗体跟踪鼠标移动
2019/12/13 Python
简单了解python filter、map、reduce的区别
2020/01/14 Python
Python定义函数实现累计求和操作
2020/05/03 Python
CSS3感应鼠标的背景闪烁和图片缩放动画效果
2014/05/14 HTML / CSS
10分钟理解CSS3 FlexBox弹性布局
2018/12/20 HTML / CSS
师范生自我鉴定
2014/03/20 职场文书
美国留学经济担保书
2014/05/20 职场文书
代领毕业证委托书
2014/08/02 职场文书
读群众路线的心得体会
2014/09/03 职场文书
党员自我剖析材料范文
2014/10/06 职场文书
玩手机检讨书1000字
2014/10/20 职场文书