首页
/ 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 格式的库也同样有效。理解这个问题的本质有助于开发者更好地处理类似的模块解析问题。

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

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
197
2.17 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
208
285
pytorchpytorch
Ascend Extension for PyTorch
Python
59
94
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
974
574
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
549
81
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.02 K
399
communitycommunity
本项目是CANN开源社区的核心管理仓库,包含社区的治理章程、治理组织、通用操作指引及流程规范等基础信息
393
27
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
1.2 K
133