解决 "Cannot use import statement outside a module" 错误

这个错误通常发生在 JavaScript 环境中不支持 ES6 模块语法(import/export)的情况下。以下是详细的解决方案,适用于不同环境(浏览器、Node.js、打包工具等)。


1. 浏览器环境

错误原因

浏览器默认不支持 import/export 语法,除非显式声明 <script type="module">

解决方案

(1) 使用 type="module"

在 HTML 文件中引入脚本时,添加 type="module"

html 复制代码
<script type="module" src="your-script.js"></script>

注意:

  • 必须通过 HTTP 服务器(如 http://localhost)运行,不能直接打开本地文件(file://)。
  • 模块脚本默认启用严格模式,并遵循 CORS 规则。

(2) 使用打包工具(推荐)

如果项目较复杂,建议使用 Webpack、Vite、Rollup 等打包工具处理模块依赖:

bash 复制代码
npm install webpack webpack-cli --save-dev

配置 webpack.config.js

javascript 复制代码
module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'bundle.js',
    path: __dirname + '/dist',
  },
  mode: 'development',
};

然后在 HTML 中引入打包后的文件:

html 复制代码
<script src="dist/bundle.js"></script>

2. Node.js 环境

错误原因

Node.js 默认使用 CommonJS (require),除非显式启用 ES6 模块。

解决方案

(1) 在 package.json 中设置 "type": "module"

json 复制代码
{
  "name": "my-app",
  "version": "1.0.0",
  "type": "module",  // 启用 ES6 模块
  "main": "index.js"
}

然后就可以使用 import

javascript 复制代码
import fs from 'fs';

(2) 使用 .mjs 扩展名

如果不想修改 package.json,可以将文件扩展名改为 .mjs

javascript 复制代码
// math.mjs
export function add(a, b) { return a + b; }

// index.mjs
import { add } from './math.mjs';

(3) 使用 Babel 转换(兼容旧版本 Node.js)

安装 Babel:

bash 复制代码
npm install @babel/core @babel/node @babel/preset-env --save-dev

创建 .babelrc

json 复制代码
{
  "presets": ["@babel/preset-env"]
}

运行代码:

bash 复制代码
npx babel-node index.js

3. 通用解决方案(Babel + Webpack)

如果项目需要兼容多种环境(浏览器 + Node.js),推荐使用 Babel + Webpack 组合:

  1. 安装依赖

    bash 复制代码
    npm install webpack webpack-cli babel-loader @babel/core @babel/preset-env --save-dev
  2. 配置 webpack.config.js

    javascript 复制代码
    module.exports = {
      module: {
        rules: [
          {
            test: /\.js$/,
            exclude: /node_modules/,
            use: {
              loader: 'babel-loader',
              options: {
                presets: ['@babel/preset-env']
              }
            }
          }
        ]
      }
    };
  3. 运行打包

    bash 复制代码
    npx webpack

4. 常见错误排查

  1. 路径问题
    • 确保 import 路径正确(如 './module.js' 而不是 'module.js')。
  2. CORS 限制
    • 浏览器模块必须通过 HTTP 服务器运行(如 live-servervite)。
  3. 文件扩展名
    • Node.js 中建议使用 .mjs"type": "module"
  4. 混合模块系统
    • 避免在同一个项目混用 requireimport

总结

环境 解决方案
浏览器 <script type="module"> 或 Webpack/Vite
Node.js "type": "module".mjs 或 Babel
通用项目 Webpack + Babel

如果仍有问题,请检查:

  • 是否正确配置了模块系统?
  • 是否使用了正确的文件扩展名?
  • 是否运行在正确的服务器环境下?
相关推荐
吃饭最爱22 分钟前
html的基础知识
前端·html
我没想到原来他们都是一堆坏人23 分钟前
(未完待续...)如何编写一个用于构建python web项目镜像的dockerfile文件
java·前端·python
前端Hardy44 分钟前
HTML&CSS:有趣的漂流瓶
前端·javascript·css
前端Hardy1 小时前
HTML&CSS :惊艳 UI 必备!卡片堆叠动画
前端·javascript·css
无羡仙1 小时前
替代 Object.freeze 的精准只读模式
前端·javascript
web前端1231 小时前
Java客户端开发指南 - 与Web开发对比分析
前端
龙在天1 小时前
前端 9大 设计模式
前端
搞个锤子哟1 小时前
网站页面放大缩小带来的问题
前端
hj5914_前端新手1 小时前
React 基础 - useState、useContext/createContext
前端·react.js
半花1 小时前
【Vue】defineProps、defineEmits 和 defineExpose
前端·vue.js