javascript es6系列教程 - 不定参数与展开运算符(...)
三个点(...)在es6中,有两个含义:
- 用在形参中, 表示传递给他的参数集合, 类似于arguments, 叫不定参数. 语法格式: 在形参面前加三个点( ... )
- 用在数组前面,可以把数组的值全部打散,展开,叫展开运算符. 语法格式: 在数组面前加三个点( ... )
求不定参数的和,以前可以用arguments来做,现在可以用不定参数来做,如下:

1 function add( ...values ){
2 console.log( values ); // [10, 20, 30]
3 let sum = 0;
4 for( let i = 0, len = values.length; i < len; i++ ){
5 sum += values[i];
6 }
7 return sum;
8 }
9 var res = add( 10, 20, 30 );
10 console.log( res ); //60

1 function add( ...keys, last ) { //报错,不定参数只能放在最后面
2
3 }
1 // function add( ...key1, ...key2 ){ //报错,一个函数不能出现多个不定参数
2
3 // }
筛选拷贝对象的属性,之前我们是这样子做的:

1 function pick( src ){
2 let target = Object.create( null );//创建一个空对象,跟new Object不同
3 for( let i = 1, len = arguments.length; i < len; i++ ){
4 target[arguments[i]] = src[arguments[i]];
5 }
6 return target;
7 }
8 let user = {
9 name : 'ghostwu',
10 age : 22,
11 sex : 'man',
12 };
13 var obj = pick( user, 'name', 'age' ); //拷贝user对象的name和age属性
14 console.log( obj ); //{name: "ghostwu", age: 22}

这样做没有什么问题,读取属性我们始终要记得从1开始, 因为arguments对象的索引0 被 src这个参数占据了. 用不定参数修改如下:

1 function pick( src, ...keys ){
2 console.log( keys ); //['name','age'];
3 let target = Object.create( null );
4 for( let i = 0, len = keys.length; i < len; i++ ){
5 target[keys[i]] = src[keys[i]];
6 }
7 return target;
8 }
9
10 let user = {
11 name : 'ghostwu',
12 age : 22,
13 sex : 'man',
14 };
15
16 var obj = pick( user, 'name', 'age' );
17 console.log( obj );

以上方式,更符合数组操作习惯, 拿来就用,不要老是记着从1开始
不定参数与arguments类似,当初设计的目的就是为了取代arguments,那不定参数会不会影响arguments呢?

1 function show( ...keys ){
2 console.log( keys.length ); //3
3 console.log( arguments.length ); //3
4 keys[0] = 1000;
5 console.log( keys[0], keys[1], keys[2] ); // 1000,20,30
6 console.log( arguments[0], arguments[1], arguments[2] ); //10,20,30
7 }
8 show( 10, 20, 30 );

不定参数修改之后,arguments并不会受到影响
展开运算符:
1 let a = 10, b = 20;
2 console.log( Math.max( a, b ) ); //20
1 let arr = [ 1, 3, 0, -1, 20, 100 ];
2 console.log( Math.max( arr ) );//NaN, max不能接收数组参数
我们可以借助apply的语法,把数组传递进去
1 let arr = [ 1, 3, 0, -1, 20, 100 ];
2 console.log( Math.max.apply( Math, arr ) );//100
有了展开运算符之后,更简单
1 let arr = [ 1, 3, 0, -1, 20, 100 ];
2 console.log( Math.max( ...arr ) ); //100 ...: 把数组展开
3 console.log( Math.max( ...arr, 1000 ) ); //1000
javascript es6系列教程 - 不定参数与展开运算符(...)的更多相关文章
- [js高手之路] es6系列教程 - 不定参数与展开运算符(...)
三个点(...)在es6中,有两个含义: 用在形参中, 表示传递给他的参数集合, 类似于arguments, 叫不定参数. 语法格式: 在形参面前加三个点( ... ) 用在数组前面,可以把数组的值 ...
- [js高手之路] es6系列教程 - 对象功能扩展详解
第一:字面量对象的方法,支持缩写形式 //es6之前,这么写 var User = { name : 'ghostwu', showName : function(){ return this.nam ...
- [js高手之路] es6系列教程 - 迭代器,生成器,for...of,entries,values,keys等详解
接着上文[js高手之路] es6系列教程 - 迭代器与生成器详解继续. 在es6中引入了一个新的循环结构for ....of, 主要是用来循环可迭代的对象,那么什么是可迭代的对象呢? 可迭代的对象一般 ...
- JavaScript进阶系列04,函数参数个数不确定情况下的解决方案
本篇主要体验函数参数个数不确定情况下的一个解决方案.先来看一段使用函数作为参数进行计算的实例. var calculate = function(x, y, fn) { return fn(x, y) ...
- [js高手之路]es6系列教程 - 解构详解
解构通俗点说,就是通过一种特定格式,快捷的读取对象/数组中的数据的方法, es6之前,我们通过对象名称[键] 读取数据 var User = { 'name' : 'ghostwu', 'age' : ...
- 《JavaScript语言入门教程》记录整理:运算符、语法和标准库
目录 运算符 算数运算符 比较运算符 布尔运算符 二进制位运算符 void和逗号运算符 运算顺序 语法 数据类型的转换 错误处理机制 编程风格 console对象和控制台 标准库 Object对象 属 ...
- [js高手之路] es6系列教程 - 函数的默认参数详解
在ES6之前,我们一般用短路表达式处理默认参数 function show( a, b ){ var a = a || 10; var b = b || 20; console.log( a, b ) ...
- 《无所不能的JavaScript编程系列:arguments 参数对象》
前言:无所不能的JavaScript JavaScript起源于Netscape公司的LiveScript语言,这是一种基于对象和事件驱动的客户端脚本语言,最初的设计是为了检验HTML表单输入的正确性 ...
- [js高手之路] es6系列教程 - 箭头函数详解
箭头函数是es6新增的非常有意思的特性,初次写起来,可能会觉得别扭,习惯之后,会发现很精简. 什么是箭头函数? 箭头函数是一种使用箭头( => )定义函数的新语法, 主要有以下特性: 不能通过n ...
随机推荐
- Java面试宝典(说说&和&&的区别)
&和&&都可以用作逻辑与的运算符,表示逻辑与(and),当运算符两边的表达式的结果都为true时,整个运算结果才为true,否则,只要有一方为false,则结果为false. ...
- 配置java环境jdk
最近尝试改公司的项目中的一个后台管理系统,前后台都让我一个做,所以要配置一下java环境: 1. 按装jdk 1.6//2. 安装eclipse3. 安装maven4. 安装eclispe的maven ...
- log4j动态监听配置修改
一般情况下,log4j的配置文件是log4j.properties.但是每次我们修改了配置文件之后程序并不会自动去加载,而需要我们去重启程序.那么怎么样才能让程序不用重启就监听到变化呢.代码如下: p ...
- joomla 的语言翻译
最近装了留言板组件 phocaguestbook,发觉没有中文翻译. 于是在 components\com_phocaguestbook\language\en-GB 找到了英文的文件. 依葫芦画瓢, ...
- [JSP] Action Tags
1.: forward转发请求to another resource (可能是jsp, html,等). 语法: <jsp:forward page="relativeURL | &l ...
- p1472 Cow Pedigrees
用dp[i][j]记录i个点,组成深度恰好为j的方案数.arr[i][j]记录i个点,深度<=j的方案数.那么dp[i][j]只有i为奇数时不为0.而arr[i][j]等于dp[i][j]的前缀 ...
- 2-sat学习笔记
前后缀建图 例:要求n个变量满足至多有1个为true. 暴力:一个点的true向其它n-1个点的false连边,复杂度O(n^2). 正解:prei表示前i个点是否有真. prei的true向prei ...
- 4.1.7 Cutting Game(POJ 2311)
Problem description: 两个人在玩如下游戏. 准备一张分成 w*h 的格子的长方形纸张,两人轮流切割纸张.要沿着格子的边界切割,水平或者垂直地将纸张切成两部分.切割了n次之后就得到了 ...
- 20165309 技能学习经验与C语言
技能学习经验与C语言 技能学习经验 你有什么技能比大多人(超过90%以上)更好?针对这个技能的获取你有什么成功的经验?与老师博客中的学习经验有什么共通之处? 从小到大,或是出于兴趣.或是出于父母的要求 ...
- consul总结
一.介绍 内置了服务注册与发现框 架.分布一致性协议实现.健康检查.Key/Value存储.多数据中心方案,不再需要依赖其他工具(比如ZooKeeper等)服务部署简单,只有一个可运行的二进制的包.每 ...