Redux Toolkit 2.0 迁移中 getDefaultEnhancers 问题解析
问题背景
在从 Redux Toolkit 1.x 升级到 2.0 版本的过程中,开发者可能会遇到一个常见问题:getDefaultEnhancers is not a function
错误。这个问题通常出现在配置 Redux store 时,特别是在使用 configureStore
API 时。
问题现象
当开发者按照 Redux Toolkit 2.0 的文档配置 store 时,可能会编写如下代码:
const store = configureStore({
reducer: rootReducer,
middleware: (getDefaultMiddleware) =>
getDefaultMiddleware().concat(additionalMiddleware),
enhancers: (getDefaultEnhancers) => {
return getDefaultEnhancers().concat(customEnhancer);
}
});
然而运行时却会遇到 getDefaultEnhancers is not a function
的错误提示。
根本原因
这个问题的主要原因是项目中实际上仍然在使用 Redux Toolkit 1.x 版本的代码。在 1.x 版本中,enhancers
配置项接收的是一个数组,而在 2.0 版本中,它接收的是一个回调函数。
具体差异:
- Redux Toolkit 1.x:
enhancers
接收默认 enhancers 数组 - Redux Toolkit 2.0:
enhancers
接收一个返回 enhancers 数组的函数
解决方案
要解决这个问题,可以采取以下步骤:
-
确认 Redux Toolkit 版本: 运行
npm ls @reduxjs/toolkit
或yarn why @reduxjs/toolkit
确认项目中实际使用的版本。 -
清理项目依赖: 删除
node_modules
和 lock 文件(package-lock.json 或 yarn.lock),然后重新安装依赖。 -
检查导入路径: 确保所有从 Redux Toolkit 的导入路径都是正确的。在 2.0 版本中,一些内部路径发生了变化,特别是移除了
/dist
路径。错误示例:
import { EntityState } from '@reduxjs/toolkit/dist/entities/models';
正确示例:
import { EntityState } from '@reduxjs/toolkit';
-
更新类型定义: 注意 Redux Toolkit 2.0 中对类型系统的改进,如
EntityState
现在需要显式指定 ID 类型。
最佳实践
为了避免这类问题,在升级 Redux Toolkit 时建议:
- 仔细阅读官方迁移指南
- 逐步升级,先解决主要 API 变更
- 使用 TypeScript 可以帮助捕获一些类型相关的错误
- 建立完善的测试覆盖,确保升级不会破坏现有功能
总结
Redux Toolkit 2.0 带来了许多改进,但在升级过程中可能会遇到一些兼容性问题。getDefaultEnhancers is not a function
错误通常表明项目中混合了 1.x 和 2.0 版本的代码。通过彻底检查依赖关系、更新导入路径和调整配置方式,可以顺利解决这个问题。
- QQwen3-Next-80B-A3B-InstructQwen3-Next-80B-A3B-Instruct 是一款支持超长上下文(最高 256K tokens)、具备高效推理与卓越性能的指令微调大模型00
- QQwen3-Next-80B-A3B-ThinkingQwen3-Next-80B-A3B-Thinking 在复杂推理和强化学习任务中超越 30B–32B 同类模型,并在多项基准测试中优于 Gemini-2.5-Flash-Thinking00
GitCode-文心大模型-智源研究院AI应用开发大赛
GitCode&文心大模型&智源研究院强强联合,发起的AI应用开发大赛;总奖池8W,单人最高可得价值3W奖励。快来参加吧~0162DuiLib_Ultimate
DuiLib_Ultimate是duilib库的增强拓展版,库修复了大量用户在开发使用中反馈的Bug,新增了更加贴近产品开发需求的功能,并持续维护更新。C++03GitCode百大开源项目
GitCode百大计划旨在表彰GitCode平台上积极推动项目社区化,拥有广泛影响力的G-Star项目,入选项目不仅代表了GitCode开源生态的蓬勃发展,也反映了当下开源行业的发展趋势。08- HHunyuan-MT-7B腾讯混元翻译模型主要支持33种语言间的互译,包括中国五种少数民族语言。00
GOT-OCR-2.0-hf
阶跃星辰StepFun推出的GOT-OCR-2.0-hf是一款强大的多语言OCR开源模型,支持从普通文档到复杂场景的文字识别。它能精准处理表格、图表、数学公式、几何图形甚至乐谱等特殊内容,输出结果可通过第三方工具渲染成多种格式。模型支持1024×1024高分辨率输入,具备多页批量处理、动态分块识别和交互式区域选择等创新功能,用户可通过坐标或颜色指定识别区域。基于Apache 2.0协议开源,提供Hugging Face演示和完整代码,适用于学术研究到工业应用的广泛场景,为OCR领域带来突破性解决方案。00- HHowToCook程序员在家做饭方法指南。Programmer's guide about how to cook at home (Chinese only).Dockerfile04
- PpathwayPathway is an open framework for high-throughput and low-latency real-time data processing.Python00
- Dd2l-zh《动手学深度学习》:面向中文读者、能运行、可讨论。中英文版被70多个国家的500多所大学用于教学。Python011
热门内容推荐
最新内容推荐
项目优选









