JS 柯里化函数随笔
简洁版
function curry(fn) { return function curried(...args) { if (args.length >= fn.length) { return fn(...args); } return function(...args2) { return curried(...args.concat(args2)); } }; } var sum = (a, b, c) => a + b + c; var cf = curry(sum); cf(1, 2, 3); cf(1, 2)(3); cf(1)(2, 3); cf(1)(2)(3);
更细致的模拟实现
const slice = Array.prototype.slice; const curryMaker = function(fn, len) { const curriedArgs = slice.call(arguments, 2); return curry.apply(this, [fn, (len || fn.length), ...curriedArgs]); }; const curry = function(fn, len) { const curriedArgs = slice.call(arguments, 2); return function() { const args = [...curriedArgs, ...arguments]; // 如果与预期的参数长度一致,则执行函数,获取返回值 if (args.length >= len) { return fn.apply(this, args); } // 否则,整理入参,返回curry函数的结果 return curry.apply(this, [fn, len, ...args]); }; }; function calcSum() { return [...arguments].reduce((pre, value) => { return pre + value }, 0); } const calcSumCurry = curry(calcSum, 4); const nextCalc = calcSumCurry(1, 2); console.log(nextCalc(3)(4));
分类:
JavaScript
标签:
JavaScript
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 【杂谈】分布式事务——高大上的无用知识?