副作用是函数执行时除返回值外对外部状态的可观察改变,如修改全局变量、DOM、发起网络请求等;纯函数需满足相同输入恒得相同输出且无任何副作用,应通过参数传入依赖、使用不可变操作等方式实现。
副作用是指函数在执行过程中,除了返回值之外,还对外部状态产生了可观察的改变。比如修改了全局变量、改变了传入对象的属性、发起了网络请求、触发了 DOM 更新、调用了 console.log 等——这些行为都属于副作用。
常见副作用来源包括:
纯函数满足两个条件:相同输入永远返回相同输出;不产生任何副作用。要避免副作用,可以这样做:
例如:
❌ 有副作用:function addTax(items) { items.forEach(item => item.price *= 1.1); return items; }
✅ 无副作用:function addTax(items) { return items.map(item => ({ ...item, price: item.price * 1.1 })); }
实际开发中完全消除副作用是不可能也不必要的(比如渲染页面、保存用户数据)。重点是把副作用“隔离”和“显式化”:
React 中用 useEffect 管理副作用,而不是散落在 render 逻辑里基本上就这些。副作用本身不可怕,可怕的是它悄悄发生、难以追踪。把变化收束到明确的位置,代码就更可靠、易测、好维护。