三种解决办法 ReferenceError: __dirname is not defined in ES module scope

1 fileURLToPath 结合 import.meta.url

fileURLToPath Added in: v10.12.0 import.meta.url Added in: v10

ts 复制代码
import path from 'path';
import { fileURLToPath } from 'url';

const __dirname = path.dirname(fileURLToPath(import.meta.url));

2. import.meta.dirname ✔️

Added in: v21.2.0, v20.11.0

最少依赖最推荐写法

ts 复制代码
const __dirname = import.meta.dirname
  • 冷知识 1:import 虽然不能在 cjs 中使用,但是 import.meta 可以
  • 冷知识 2:Node.js 的 LTS 已经是 v22 了,v18 还有三周就要过保了,v20 也只有一年保质期了。LTS 意味着稳定和安全,大家踊跃升级呀。

当前时间数据:2025-4-10

Release Security Support Latest
23 Ends in 1 month and 3 weeks(01 Jun 2025) 23.11.0(01 Apr 2025)
22 (LTS) Ends in 2 years(30 Apr 2027) 22.14.0(11 Feb 2025)
20 (LTS) Ends in 1 year(30 Apr 2026) 20.19.0(13 Mar 2025)
18 (LTS) Ends in 3 weeks(30 Apr 2025) 18.20.8(27 Mar 2025)

来自 endoflife.date/nodejs

可以看下 import.meta 里面还有哪些值

ts 复制代码
console.log('process.versions:', process.versions.node);
console.log(import.meta);
ts 复制代码
❯ node import.meta.js
process.versions: 22.7.0
[Object: null prototype] {
  dirname: 'F:\\temp',
  filename: 'F:\\temp\\import.meta.js',
  resolve: [Function: resolve],
  url: 'file:///F:/temp/import.meta.js'
}

3. new URL 结合 import.meta.url

只能在非 Windows 操作系统中用。Macos 系统未尝试大家可以帮忙试试。

ts 复制代码
import path from 'path'

const __dirname = path.dirname(new URL(import.meta.url).pathname)

Windows 下返回 __dirname: /F:/temp 正确应该是 F:\\temp

更多详见 nodejs.org/docs/latest...

相关推荐
MaisieKim_17 小时前
python与nodejs哪个性能高
前端·python·node.js
水煮白菜王17 小时前
深入理解 Webpack 核心机制与编译流程
前端·webpack·node.js
程序员拂雨18 小时前
Express知识框架
node.js·express
大G哥18 小时前
项目中利用webpack的require.context实现批量引入/导入图片
前端·webpack·node.js
七冬与小糖2 天前
【本地搭建npm私服】使用Verdaccio
前端·npm·node.js
巴巴_羊2 天前
webpack和vite区别
前端·webpack·node.js
亦世凡华、2 天前
前端npm包发布流程:从准备到上线的完整指南
前端·经验分享·npm·node.js·npm发包
X01动力装甲2 天前
Node.js 24.0 正式发布:性能跃升与开发体验全面升级
node.js
q567315232 天前
Node.js数据抓取技术实战示例
爬虫·python·scrapy·node.js
巴巴_羊2 天前
yarn npm pnpm
前端·npm·node.js