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获取IP、MAC和主机名的五种方法
Nov 14 Javascript
使用jQuery不判断浏览器高度解决iframe自适应高度问题
Dec 16 Javascript
IE7浏览器窗口大小改变事件执行多次bug及IE6/IE7/IE8下resize问题
Aug 21 Javascript
微信小程序开发(二)图片上传+服务端接收详解
Jan 11 Javascript
JavaScript中的toString()和toLocaleString()方法的区别
Feb 15 Javascript
Vue插件从封装到发布的完整步骤记录
Feb 28 Javascript
Vue循环中多个input绑定指定v-model实例
Aug 31 Javascript
vue实现图书管理系统
Dec 29 Vue.js
Node快速切换版本、版本回退(降级)、版本更新(升级)
Jan 07 Javascript
jQuery是用来干什么的 jquery其实就是一个js框架
Feb 04 jQuery
JS实现百度搜索框
Feb 25 Javascript
如何理解Vue前后端数据交互与显示
May 10 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
超小PHP小马小结(方便查找后门的朋友)
2012/05/05 PHP
php中出现空白页的原因及解决方法汇总
2014/07/08 PHP
在Ubuntu 14.04上部署 PHP 环境及 WordPress
2014/09/02 PHP
Laravel Memcached缓存驱动的配置与应用方法分析
2016/10/08 PHP
背景音乐每次刷新都可以自动更换
2007/02/01 Javascript
js实现权限树的更新权限时的全选全消功能
2009/02/17 Javascript
Javascript isArray 数组类型检测函数
2009/10/08 Javascript
推荐11款jQuery开发的复选框和单选框美化插件
2011/08/02 Javascript
杨氏矩阵查找的JS代码
2013/03/21 Javascript
使用jQuery validate 验证注册表单实例演示
2013/03/25 Javascript
node.js中的url.parse方法使用说明
2014/12/10 Javascript
使用纯javascript实现放大镜效果
2015/03/18 Javascript
Javascript中的getUTCHours()方法使用详解
2015/06/10 Javascript
js判断子窗体是否关闭的方法
2015/08/11 Javascript
浅析Node.js 中 Stream API 的使用
2015/10/23 Javascript
jquery判断当前浏览器的实现代码
2015/11/07 Javascript
jQuery mobile 移动web(6)
2015/12/20 Javascript
NodeJS如何实现同步的方法示例
2018/08/24 NodeJs
Vue axios全局拦截 get请求、post请求、配置请求的实例代码
2018/11/28 Javascript
Mpvue中使用Vant Weapp组件库的方法步骤
2019/05/16 Javascript
JS实现判断数组是否包含某个元素示例
2019/05/24 Javascript
Nest.js 授权验证的方法示例
2021/02/22 Javascript
[01:46]辉夜杯—打造中国DOTA新格局
2015/12/25 DOTA
[43:18]NB vs Infamous 2019国际邀请赛淘汰赛 败者组 BO3 第一场 8.22
2019/09/05 DOTA
Python基础之文件读取的讲解
2019/02/16 Python
Python实现去除图片中指定颜色的像素功能示例
2019/04/13 Python
PyCharm License Activation激活码失效问题的解决方法(图文详解)
2020/03/12 Python
python如何求100以内的素数
2020/05/27 Python
树莓派4B安装Tensorflow的方法步骤
2020/07/16 Python
Python项目实战之使用Django框架实现支付宝付款功能
2021/02/23 Python
阿玛尼美妆加拿大官方商城:Giorgio Armani Beauty加拿大
2017/10/24 全球购物
Python里面search()和match()的区别
2016/09/21 面试题
旅游管理专业生自荐信范文
2014/01/02 职场文书
教育实践活动对照检查材料
2014/09/23 职场文书
用 Python 元类的特性实现 ORM 框架
2021/05/19 Python
Win11筛选键导致键盘失灵怎么解决? Win11关闭筛选键的技巧
2022/04/08 数码科技