js 实现 sum 函数无限累加
2022/8/24 6:53:02
本文主要是介绍js 实现 sum 函数无限累加,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
// 无限累加 sum // 一共做两件事: // 1. 调用一次返回当前计算函数本身,该函数主要作用之一为合并多次调用传的不同数量的参数 // 2. 给返回的函数增加 valueOf 最终计算结果的方法 function sum(...args) { // 定义返回的闭包函数 const f = (...rest) => sum(...args, ...rest); // 每次执行到这里都会重新定义 f.valueOf,最终计算的时候调用 valueOf 拿到的 sum 的 args 是在前面几次调用 sum 之后合并后的最终参数列表 f.valueOf = () => args.reduce((a, b) => a + b); // 返回闭包函数 return f; } console.log(sum(1, 2, 3).valueOf()); //6 console.log(sum(2, 3)(2).valueOf()); //7 console.log(sum(1)(2)(3)(4).valueOf()); //10 console.log(sum(2)(4, 1)(2).valueOf()); //9
// 如果不使用 valueOf,可直接进行计算,如下示例,应如何处理。 function sum2(...args) { // 直接返回计算结果 let res = args.reduce((a, b) => a + b); return res; } //=> 15 console.log(sum2(1, 2, 3) + sum2(4, 5)); //=> 100 console.log(sum2(10) * sum2(10));
参考链接:
https://blog.csdn.net/Mr_carry/article/details/109025517
https://github.com/shfshanyue/Daily-Question/issues/428
这篇关于js 实现 sum 函数无限累加的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-15useCallback教程:React Hook入门与实践
- 2024-11-15React中使用useContext开发:初学者指南
- 2024-11-15拖拽排序js案例详解:新手入门教程
- 2024-11-15React中的自定义Hooks案例详解
- 2024-11-14受控组件项目实战:从零开始打造你的第一个React项目
- 2024-11-14React中useEffect开发入门教程
- 2024-11-14React中的useMemo教程:从入门到实践
- 2024-11-14useReducer开发入门教程:轻松掌握React中的useReducer
- 2024-11-14useRef开发入门教程:轻松掌握React中的useRef用法
- 2024-11-14useState开发:React中的状态管理入门教程