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

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

2025-05-06 10:26:22作者:史锋燃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 格式的库也同样有效。理解这个问题的本质有助于开发者更好地处理类似的模块解析问题。

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