ECMAScript6函数剩余参数(Rest Parameters)


Posted in Javascript onJune 12, 2015

我们知道JS函数内部有个arguments对象,可以拿到全部实参。现在ES6给我们带来了一个新的对象,可以拿到除开始参数外的参数,即剩余参数(废话好多 O(∩_∩)O~)。

这个新的对象和arguments不一样,它是程序员自定义的一个普通标识符,只是需要在前面加上三个点:...

function func(a, ...rest) {
 console.log(a)
 console.log(rest)
}
func(1)
func(1, 2, 3, 4)

注意func的第二个参数rest,前面有三个点。定义好后调用了两次,结果分别如下

ECMAScript6函数剩余参数(Rest Parameters)

可以看到第一次调用时,rest为一个空数组,第二次为[2, 3, 4]。

又比如,在前面定义2个参数

function func(a, b, ...rest) {
 console.log(a, b)
 console.log(rest)
}
func(1, 2)
func(1, 2, 3, 4)

输出结果如下

ECMAScript6函数剩余参数(Rest Parameters)

通过以上两个示例应该已经了解剩余参数的意义了吧。

剩余参数嘛,所以后面就不要再跟其它的参数了,不然会报错

function func(a, ...rest, b) {
 
}

这里在rest后面加了一个参数b,Firefox会报错

ECMAScript6函数剩余参数(Rest Parameters)

当您使用剩余参数后,函数的length属性会发生一些变化

function func(a, b, ...rest) {
}
func.length // 2

即length不包含rest,为2。

有同学会想,剩余参数前面是否可以一个参数都没有呢? 答案是肯定的

function func(...rest) {
 console.log(rest)
}
func(1) // [1]
func(1, 2, 3, 4) // [1,2,3,4]

这里的rest实际和arguments功能差不多,有同学想这不就替代了arguments吗? ECMAScript就是这个打算,在被废弃的ES4里就已经有Rest Parameters(熟悉AS3的同学应该了解),ES4被废弃后,Rest Parameters被保留到了ES6。

请注意,rest不能和arguments一起使用,会报错

function func(...rest) {
 console.log(rest)
 console.log(arguments)
}

Firefox控制台如下

ECMAScript6函数剩余参数(Rest Parameters)

arguments和剩余参数的区别

arguments是一个伪数组(Array-like)
剩余参数是一个真正数组(Array),具有Array.prototype上的所有方法
arguments上有callee,callee上有caller

function func(a, ...rest) {
  console.log(rest instanceof Array)
}
func(1, 2) // true

最后我们以一个剩余参数实际应用作为结束

/*
 * 任意个数相加
 *
 * **示例**
 * sum(1)
 * sum(1, 2)
 * sum(1, 2, 3)
 */
function sum(first, ...rest) {
  var result = first
  var i = 0
  var len = rest.length
  while (i < len) {
    result += rest[i]
    i++
  }
  return result
}

以上所述就是本文的全部内容了,希望大家能喜欢。

Javascript 相关文章推荐
用cssText批量修改样式
Aug 29 Javascript
基于jquery的兼容各种浏览器的iframe自适应高度的脚本
Aug 13 Javascript
JavaScript数据结构与算法之栈详解
Mar 12 Javascript
Javascript之BOM(window对象)详解
May 25 Javascript
js 实现数值的千分位及保存小数方法(推荐)
Aug 01 Javascript
AngularJS基础 ng-model 指令详解及示例代码
Aug 02 Javascript
js中bool值的转换及“&amp;&amp;”、“||”、 “!!”详解
Dec 21 Javascript
Angular 组件之间的交互的示例代码
Mar 24 Javascript
vue检测对象和数组的变化分析
Jun 30 Javascript
webpack开发环境和生产环境的深入理解
Nov 08 Javascript
简单分析js中的this的原理
Aug 31 Javascript
JS禁用右键、禁用Ctrl+u、禁用Ctrl+s、禁用F12的实现代码
Dec 01 Javascript
ECMAScript6函数默认参数
Jun 12 #Javascript
在JavaScript中操作时间之setYear()方法的使用
Jun 12 #Javascript
简介JavaScript中setUTCSeconds()方法的使用
Jun 12 #Javascript
JS中产生标识符方式的演变
Jun 12 #Javascript
JS中处理时间之setUTCMinutes()方法的使用
Jun 12 #Javascript
JavaScript中setUTCMilliseconds()方法的使用详解
Jun 12 #Javascript
JavaScript中setUTCFullYear()方法的使用简介
Jun 12 #Javascript
You might like
php出现Cannot modify header information问题的解决方法大全
2008/04/09 PHP
PHP写的获取各搜索蜘蛛爬行记录代码
2012/08/21 PHP
PHP下获取上个月、下个月、本月的日期(strtotime,date)
2014/02/02 PHP
浅析ThinkPHP中execute和query方法的区别
2014/06/13 PHP
PHP采用XML-RPC构造Web Service实例教程
2014/07/16 PHP
php 输出json及显示json中的中文汉字详解及实例
2016/11/09 PHP
代码精简的可以实现元素圆角的js函数
2007/07/21 Javascript
利用JS重写Cognos右键菜单的实现代码
2010/04/11 Javascript
jquery关于页面焦点的定位(文本框获取焦点时改变样式 )
2010/09/10 Javascript
jQuery怎么解析Json字符串(Json格式/Json对象)
2013/08/09 Javascript
全面解析Bootstrap排版使用方法(标题)
2015/11/30 Javascript
简单讲解jQuery中的子元素过滤选择器
2016/04/18 Javascript
jQ处理xml文件和xml字符串的方法(详解)
2016/11/22 Javascript
利用JQuery操作iframe父页面、子页面的元素和方法汇总
2017/09/10 jQuery
vue-dplayer 视频播放器实例代码
2019/11/08 Javascript
vue实现全屏滚动效果(非fullpage.js)
2020/03/07 Javascript
python网络编程之读取网站根目录实例
2014/09/30 Python
Python第三方库的安装方法总结
2016/06/06 Python
Python 递归函数详解及实例
2016/12/27 Python
Python编程实现微信企业号文本消息推送功能示例
2017/08/21 Python
python三引号输出方法
2019/02/27 Python
在pytorch中查看可训练参数的例子
2019/08/18 Python
PYTHON绘制雷达图代码实例
2019/10/15 Python
linux系统下pip升级报错的解决方法
2021/01/31 Python
Python3利用openpyxl读写Excel文件的方法实例
2021/02/03 Python
css3翻牌翻数字的示例代码
2020/02/07 HTML / CSS
专科毕业生就业推荐信
2013/11/01 职场文书
外贸专业求职信
2014/03/09 职场文书
党员创先争优活动总结
2014/05/04 职场文书
环保建议书100字
2014/05/14 职场文书
乡镇干部党的群众路线教育实践活动个人对照检查材料
2014/09/24 职场文书
2014幼儿园教育教学工作总结
2014/12/17 职场文书
2015年酒店客房部工作总结
2015/04/25 职场文书
2015小学新教师个人工作总结
2015/10/14 职场文书
《金钱的魔力》教学反思
2016/02/20 职场文书
python3 sqlite3限制条件查询的操作
2021/04/07 Python