Node.js中不支持require和import两种导入模块的混用

ops/2025/2/22 21:22:48/

最近在整理Node.js相关的知识点,发现通过Node.js支持的两个模块导入语句require和import在同时使用时会发生错误,而且错误非常诡异。
例如,在先使用require导入模块,在使用import导入模块时,出现require无法识别,
在先使用import导入模块,在使用require导入模块时,同样出现了require无法识别,建议使用import代替。

ReferenceError: require is not defined in ES module scope, you can use import instead
const readFile = require('fs').readFile;^ReferenceError: require is not defined in ES module scope, you can use import insteadat file:///d:/Software/Electron/JavaScript/LearnProject/NodeJsProject/BasicModules/FileOperation.js:10:18at ModuleJob.run (node:internal/modules/esm/module_job:271:25)at async onImport.tracePromise.__proto__ (node:internal/modules/esm/loader:547:26)at async asyncRunEntryPointWithESMLoader (node:internal/modules/run_main:116:5)Node.js v22.13.1
'use strict'
//const {randomInt} = require('node:crypto');
import {randomInt} from 'node:crypto';
const n = randomInt(0,100);
console.log('BasicModules.js: randomInt:', n);//import {readFile} from 'node:fs';
const readFile = require('fs').readFile;
console.log("BasicModules.js: readFile start");readFile('BasicModules.js', 'utf-8', (err, data)=>{if (err) {console.log('BasicModules.js: readFile error:', err);} else {console.log('BasicModules.js: readFile data:', data);}
});console.log("BasicModules.js: readFile End");

Node.js 中无法同时使用 require 和 import 的根本原因在于两种模块系统的设计差异。以下是具体原因和解决方案的总结:

模块系统差异

  1. CommonJS(require)
    Node.js 原生支持的模块系统,同步加载模块,适用于服务端开发。
    通过 module.exports 导出,require() 导入,本质是运行时加载。
  2. ES 模块(import/export)
    官方标准化模块系统,异步加载,支持静态分析,适用于浏览器和现代 Node.js 环境。
    通过 export 导出,import 导入,编译时确定依赖关系。

报错原因分析

当文件被识别为 ES 模块 时(文件中使用了import就会自动识别为ES模块)

Node.js 默认禁用 require,因为 ES 模块设计上要求代码静态化,而 require 是动态的[[1][3]6。
错误 ReferenceError: require is not defined in ES module scope 表明当前文件被识别为 ES 模块,但尝试使用了 CommonJS 语法。

1. 解决方案

1.1 统一模块类型

方法一:显式声明模块类型
在 package.json 中添加 “type”: “module”,所有 .js 文件默认视为 ES 模块;使用 .cjs 扩展名表示 CommonJS 模块。

方法二:动态兼容
在 ES 模块中通过 createRequire 引入 require:

import { createRequire } from 'module';
const require = createRequire(import.meta.url); 
// 之后可使用 require()

此方式允许在 ES 模块中局部使用 CommonJS 语法[[1][7]10。

1.2 模块互操作

导入 CommonJS 模块到 ES 模块
使用 import 导入时,CommonJS 模块会被包装为默认导出:

import fs from 'fs';  // 等同于 require('fs').default 

导入 ES 模块到 CommonJS
需使用动态 import():

const loadModule = async () => {const esModule = await import('./es-module.mjs'); 
};

1.3 环境配置

Node.js 版本要求
确保版本 ≥ 14,并启用实验性 ES 模块支持(旧版本需添加 --experimental-modules 标志)。

文件扩展名
ES 模块建议使用 .mjs,CommonJS 使用 .cjs,避免解析歧义。

2. 最佳实践

项目级统一规范
新项目优先使用 ES 模块,老项目逐步迁移,避免混用。
工具链适配
使用 Babel 或 TypeScript 编译代码,兼容不同模块系统。

3. 总结

Node.js 中 require 和 import 的冲突源于模块系统的底层差异。通过统一模块类型、动态兼容或工具链适配,可解决这一问题。建议根据项目需求选择合适的模块方案,并遵循 Node.js 官方文档的模块互操作指南。


http://www.ppmy.cn/ops/160604.html

相关文章

第1章 快速认识线程

1.1 线程的介绍 对于计算机来说每一个任务就是一个进程Process,在每一个进程内部至少要有一个线程Thread是在运行中的。 1.2 快速创建并启动一个线程 1.2.1 尝试并行运行 package chapter01; import java.util.concurrent.TimeUnit; public class TryConcurrenc…

开题报告——基于Spring Boot的社区居民健康管理平台的设计与实现

关于本科毕业设计(论文)开题报告的规定 为切实做好本科毕业设计(论文)的开题报告工作,保证论文质量,特作如下规定: 一、开题报告是本科毕业设计(论文)的必经过程,所有本科生在写作毕业设计(论文)之前都必须作开题报告。 二、开题报告主要检验学生对专业知识的驾…

uni-app开发app时 使用uni.chooseLocation遇到的问题

问题一:不显示 问题二:选择地址列表一直在加载中 因为 uni-app 接口文档 中已经说明,使用腾讯的话需要开启云服务,具体可看官网,这就是为什么使用时直接不显示的原因,所以我使用的高德,但又出现…

06.Docker 镜像制作和管理

Docker 镜像制作和管理 Docker 镜像制作和管理1. 将现有容器通过 docker commit 手动构建镜像1.1 基于容器手动制作镜像步骤 2. 利用 DockerFile 文件执行 docker build 自动构建镜像2.1 Dockerfile 文件格式2.2 Dockerfile 相关指令2.2.1 FROM: 指定基础镜像2.2.2 LABEL: 指定…

国产编辑器EverEdit - 如何在EverEdit中管理工程?

1 工程管理 1.1 应用场景 用户创建工程后,会涉及到工程的管理 ,比如:打开工程、关闭工程等 1.2 使用方法 1.2.1 打开工程 单击主菜单工程 -> 打开工程,会弹出打开对话框,用户在对话框中选择需要打开的工程文件即…

VUE3+TS+element-plus项目从0开始入门 - 创建项目、认识基本结构

文章目录 写在前面1、创建vue3项目npm create vuelatestnpm i 2、项目结构.vscodevue3结构a、项目树结构b、package.jsonc、tsconfig.jsond、index.htmld、srce、main.tsf、App.vue 写在前面 开前请自行下载vs code、node.js, 在vs code里面安装Vue - Official插件。本文使用的…

典型的OSPF配置案例

案例1:单区域OSPF基础配置 场景:3台路由器直连,部署在Area 0中。 配置Router R1 interface GigabitEthernet0/0 ip address 10.1.1.1 255.255.255.0 ! router ospf 1 router-id 1.1.1.1 network 10.1.1.0 0.0.0.255 area 0 配置Router R2 interface GigabitEthernet0/0…

1、Window Android 13模拟器 将编译的映像文件导入Android Studio

1、环境准备 编译环境:Ubuntu-18.04.5编译版本:android13-release下载地址:清华大学开源软件镜像站AOSP # 下载repo # 同步代码:repo init -u https://mirrors.tuna.tsinghua.edu.cn/git/AOSP/platform/manifest -b android13-r…