JavaScript函数式编程强调纯函数:输入确定则输出唯一,且无副作用;纯函数需满足确定性与无副作用,是构建可靠、可测试、易组合代码的地基。

JavaScript 中的函数式编程是一种以函数为基本构建单元、强调不可变性与无状态逻辑的编程范式。它的核心不是“用函数写代码”,而是用特定方式设计函数:输入确定、输出可预测、不偷偷改东西。
纯函数:输入决定输出,不碰外面一寸土地
纯函数必须同时满足两个条件:
-
确定性:给定相同参数,永远返回相同结果。比如
Math.max(2, 5)每次都返回5,不看时间、不查网络、不读配置。 - 无副作用:执行过程中不修改任何外部变量、不操作 DOM、不发请求、不打印日志、不改传入的对象或数组。
✅ 正确示例:function capitalize(str) { return str.charAt(0).toUpperCase() + str.slice(1); }
无论调用多少次 capitalize("hello"),结果永远是 "Hello",且原字符串不受影响。
❌ 非纯函数反例:
let count = 0;<br>function nextId() { return ++count; }登录后复制
它依赖并修改了外部变量
count,两次调用返回不同值,无法预测。
副作用:函数悄悄干的“额外事情”
副作用就是函数在计算返回值之外,对外部世界做的任何可观测改变。常见类型包括:
- 修改全局变量或模块顶层变量(如上面的
count) - 直接修改传入的引用类型参数(如
arr.push(x)改了原数组) - 操作 DOM(
document.getElementById().innerText = ...) - 发起网络请求、读写 localStorage、调用
console.log或alert
⚠️ 注意:副作用本身不是错误,而是需要被识别、隔离和显式管理。比如 React 组件中,渲染逻辑必须纯,但 useEffect 就是专门用来收容副作用的地方。
立即学习“Java免费学习笔记(深入)”;
标签: react javascript java js 处理器 回调函数 为什么 red
还木有评论哦,快来抢沙发吧~