前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【深入理解JS核心技术】14. 什么是一元函数

【深入理解JS核心技术】14. 什么是一元函数

作者头像
达达前端
发布2022-05-11 21:23:40
5260
发布2022-05-11 21:23:40
举报
文章被收录于专栏:达达前端

一元函数(即monadic)是一个只接受一个参数的函数。它代表函数接受的单个参数。

代码语言:javascript
复制
const unaryFunction = (a) => console.log(a + 10); // Add 10 to the given argument and display the value
复制代码

参数扩展与收集

ECMAScript 6 新增了扩展操作符,使用它可以非常简洁地操作和组合集合数据。扩展操作符最有用的场景就是函数定义中的参数列表,在这里它可以充分利用这门语言的弱类型及参数长度可变的特点。扩展操作符既可以用于调用函数时传参,也可以用于定义函数参数。

  1. 扩展参数
代码语言:javascript
复制
function getProduct(a, b, c = 1) { 
 return a * b * c; 
} 

let getSum = (a, b, c = 0) => { 
 return a + b + c; 
} 

console.log(getProduct(...[1,2])); // 2 
console.log(getProduct(...[1,2,3])); // 6 
console.log(getProduct(...[1,2,3,4])); // 6 

console.log(getSum(...[0,1])); // 1 
console.log(getSum(...[0,1,2])); // 3 
console.log(getSum(...[0,1,2,3])); // 3
复制代码
  1. 收集参数

在构思函数定义时,可以使用扩展操作法把不同长度的独立参数组合为一个数组。

代码语言:javascript
复制
function getSum(...values) {
 // 顺序累加values中的所有值
 // 初始值的总和为0
 return values.reduce((x,y) => x + y, 0);
}
console.log(getSum(1,2,3)); // 6
复制代码
代码语言:javascript
复制
// 不可以
function getProduct(...values, lastValue) {} 

// 可以
function ignoreFirst(firstValue, ...values) { 
 console.log(values); 
} 

ignoreFirst(); // [] 
ignoreFirst(1); // [] 
ignoreFirst(1,2); // [2] 
ignoreFirst(1,2,3); // [2, 3]
复制代码
代码语言:javascript
复制
let getSum = (...values) => { 
 return values.reduce((x, y) => x + y, 0); 
} 

console.log(getSum(1,2,3)); // 6
复制代码
代码语言:javascript
复制
function getSum(...values) { 
 console.log(arguments.length); // 3 
 console.log(arguments); // [1, 2, 3] 
 console.log(values); // [1, 2, 3] 
} 

console.log(getSum(1,2,3));
复制代码

未完结!更多内容尽情期待下一节~

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-05-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 参数扩展与收集
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档