当我们看到“重写函数让其无限相加”这个题目时,第一时间想到的就是递归。递归是指函数直接或间接地调用自身。使用递归可以很方便地实现一个无限相加的函数。
当我们看到“重写函数让其无限相加”这个题目时,第一时间想到的就是递归。递归是指函数直接或间接地调用自身。使用递归可以很方便地实现一个无限相加的函数。
下面是一个实现步骤的完整攻略:
1. 定义函数
首先,我们需要定义一个函数,函数名为add
,参数为无限个数字,返回值为一个函数。
function add() {
let args = Array.prototype.slice.call(arguments);
function sum() {
let innerArgs = Array.prototype.slice.call(arguments);
args = args.concat(innerArgs);
return sum; // 返回函数
}
sum.toString = function() {
return args.reduce(function(a, b) {
return a + b;
});
}
return sum;
}
参数使用arguments
来获取,将参数转换为数组,方便后续操作。
在函数内部,定义了一个名为sum
的函数,用于记录参数之和,并返回sum
函数本身。
最后,为sum
函数添加一个toString
方法,当在调用的时候直接返回之和。
2. 使用示例
下面是两个示例,用于说明使用该函数的方法:
示例一
add(1)(2)(3) // 6
在这个示例中,我们通过连续调用函数的方式,将1, 2, 3
三个数作为参数依次传入,最后返回的结果为它们的和6
。
示例二
add(1)(2)(3)(4)(5) // 15
在这个示例中,我们同样使用了连续调用函数的方式,将1, 2, 3, 4, 5
五个数依次传入,最后返回的结果为它们的和15
。
3. 总结
以上就是关于“重写函数让其无限相加”的完整攻略,通过递归的方式实现了连续输入无限数量的数之后求和的需求。注意,在使用时需要在每个数之间使用 ()
调用函数,否则就会返回一个返回下一个函数的函数,而不是结果。
本文标题为:javascript题目,重写函数让其无限相加


基础教程推荐
- IE8下Ajax缓存问题及解决办法 2023-01-20
- 关于 css:JavaScript 选择器的类前缀? 2022-09-21
- 前端苹果官网html+css 2023-10-27
- vue项目打包分析 2023-10-08
- 前端小白的学习之路html与css的较量【一】 2023-10-27
- ajax post下载flask文件流以及中文文件名问题 2023-02-23
- javascript-在Windows 8 Metro HTML5应用程序中保持图像质量的同时调整图像大小? 2023-10-25
- JS语法也可以有C#的switch表达式 2023-07-09
- ajax异步请求刷新 2023-01-20
- Ajax轮询请求状态(微信公众号带参数二维码登录网站) 2023-01-21