解决 "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

如果仍有问题,请检查:

  • 是否正确配置了模块系统?
  • 是否使用了正确的文件扩展名?
  • 是否运行在正确的服务器环境下?
相关推荐
SRC_BLUE_175 分钟前
NSSCTF - Web | 【第五空间 2021】pklovecloud
android·前端
golang学习记6 分钟前
从0死磕全栈之Next.js 数据安全实战指南:从零信任到安全架构
前端
云中雾丽8 分钟前
flutter中 getx 的使用
前端
Jay丶26 分钟前
聊聊入职新公司两个月,试用期没过这件事
前端·面试
ZTeam前端全栈进阶圈29 分钟前
Vue新技巧:<style>标签里的 CSS 也能响应式!
前端
ღ_233330 分钟前
vue3二次封装element-plus表格,slot透传,动态slot。
前端·javascript·vue.js
摸着石头过河的石头34 分钟前
JavaScript继承的多种实现方式详解
前端·javascript
ybb_ymm37 分钟前
前端开发之ps基本使用
前端·css
Ashley的成长之路39 分钟前
NativeScript-Vue 开发指南:直接使用 Vue构建原生移动应用
前端·javascript·vue.js
衿璃39 分钟前
Flutter应用架构设计的思考
前端·flutter