首页
/ Framer Motion 项目中 React 未定义错误的解决方案

Framer Motion 项目中 React 未定义错误的解决方案

2025-05-06 05:17:53作者:史锋燃Gardner

问题背景

在使用 Framer Motion 动画库时,开发者可能会遇到一个常见问题:当导入 Framer Motion 组件时,控制台会抛出"React is not defined"的错误。这个问题通常发生在特定配置的 React 项目中,特别是使用 Webpack 作为构建工具的环境下。

错误表现

开发者尝试导入 Framer Motion 的组件时:

import { AnimatePresence, motion } from "framer-motion";

会遇到以下两种错误情况之一:

  1. 浏览器控制台显示"Uncaught ReferenceError: React is not defined"
  2. 编译阶段报错:"Can't import the named export 'Children' from non EcmaScript module"

根本原因分析

这个问题的根源在于 Webpack 对 ECMAScript 模块(.mjs)的处理方式。Framer Motion 使用.mjs 文件作为其模块格式,而某些 Webpack 配置可能无法正确解析这种模块类型,导致 React 的引用丢失。

解决方案

方案一:修改 Webpack 配置

对于直接使用 Webpack 的项目,需要在 webpack.config.js 中添加以下规则:

module: {
  rules: [
    {
      test: /\.mjs$/,
      include: /node_modules/,
      type: "javascript/auto"
    }
  ]
}

方案二:使用 react-app-rewired 的项目

对于使用 create-react-app 并配合 react-app-rewired 的项目,可以在 config-overrides.js 中添加:

const { addWebpackModuleRule } = require('customize-cra');

module.exports = override(
  addWebpackModuleRule({
    test: /\.mjs$/,
    include: /node_modules/,
    type: "javascript/auto"
  })
);

技术原理

这个解决方案的核心是告诉 Webpack 将.mjs 文件当作普通的 JavaScript 模块来处理。通过设置type: "javascript/auto",我们覆盖了 Webpack 的默认行为,确保它能正确解析 Framer Motion 的模块格式。

预防措施

  1. 确保项目中 React 的版本与 Framer Motion 兼容
  2. 检查构建工具的配置是否支持现代 JavaScript 模块
  3. 保持 Framer Motion 库的版本更新

总结

Framer Motion 作为流行的动画库,在使用时可能会遇到模块解析问题。通过调整 Webpack 配置,我们可以轻松解决"React is not defined"的错误。这个解决方案不仅适用于 Framer Motion,对于其他使用.mjs 格式的库也同样有效。理解这个问题的本质有助于开发者更好地处理类似的模块解析问题。

登录后查看全文
热门项目推荐

热门内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
861
511
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
259
300
kernelkernel
deepin linux kernel
C
22
5
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
596
57
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K