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));
参考链接:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
2018-08-24 react 生命周期钩子里不要写逻辑,否则不生效
2018-08-24 react如何监听路由url变化
2018-08-24 react跳转url,跳转外链,新页面打开页面