JavaScript 函数柯里化的应用场景

什么是函数柯里化?

函数柯里化就将一个多参数的函数转换为只能接收一个参数的函数。通过柯里化,可以将函数的参数逐步应用,形成一个参数序列,使得函数的调用更加灵活,方便参数的复用和定制。

简单来说就是简化函数的参数接收,将多个参数尽可能的变少

简单示例

javascript 复制代码
// 普通的加法函数
function add(x, y) {
  return x + y;
}
console.log(add(2, 3)) // 输出 5

// 使用柯里化转换的加法函数
function curryAdd(x) {
  return function(y) {
    return x + y;
  }
}

const addTwo = curryAdd(2);
console.log(addTwo(3)); // 输出 5

大家可能会觉得这样做多此一举,直接传2个参数不更好吗,根据这个代码来说确实如此。

但有些场景使用函数柯里化就显得非常 Nice

应用场景

参数冗余

常规实现:参数过于冗余

javascript 复制代码
function url(proto, host, patch) {
  return `${proto}${host}${patch}`
}

url('https://', 'liuyuyang.net', '/api/get/1')
url('https://', 'liuyuyang.net', '/api/post')

柯里化实现:减少参数冗余

javascript 复制代码
function url(proto, host) {
  return function (patch) {
    return `${proto}${host}${patch}`
  }
}

const newUrl = url('https://', 'liuyuyang.net')
newUrl('/api/get/1')
newUrl('/api/post')

延迟执行

javascript 复制代码
function fn() {
  console.log("在执行内部函数之前做一些事情");

  return function () {
    // 代码逻辑
  }
}

const newFn = fn()
newFn()

函数柯里化在函数式编程中非常常见,它能够提高代码的可读性、可维护性和可复用性,使代码更加灵活和模块化。

相关推荐
JieE2127 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
冬奇Lab9 小时前
AI Workflow 定义的四次演进:从 Markdown 到 JS 脚本,再到分布式多 Agent
javascript·人工智能·agent
一颗烂土豆15 小时前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
kyriewen17 小时前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
weedsfly20 小时前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript
假如让我当三天老蒯20 小时前
前端跨域解决方案(学习用)
前端·javascript·面试
铁皮饭盒1 天前
Bun 哪比 Node.js 快?
javascript·后端
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
candyTong1 天前
RTK 技术原理:一次典型会话里,80% 上下文是怎么省下来的
javascript·后端·架构
_柳青杨2 天前
深入理解 JavaScript 事件循环
前端·javascript