https://blog.youkuaiyun.com/weixin_34329187/article/details/91396617
function currying(fn) {
let args_arr = [], max_length = fn.length
let closure = function (...args) {
// 先把参数加进去
args_arr = args_arr.concat(args)
// 如果参数没满,返回闭包等待下一次调用
if (args_arr.length < max_length) return closure
// 传递完成,执行
return fn(...args_arr)
}
return closure
}
function add(x, y, z) {
return x + y + z
}
curriedAdd = currying(add)
console.log(curriedAdd(1, 2)(3))
本文介绍了一种在JavaScript中实现函数柯里化的方法,并通过一个具体的加法函数示例展示了如何使用该技术来延迟参数的求值过程。柯里化能够帮助开发者创建更加灵活和复用性强的函数。
1万+

被折叠的 条评论
为什么被折叠?



