解决vite.config.js无法使用__dirname的问题
vite.config.js无法使用__dirname
__dirname 是 commonjs 规范的内置变量。
如果使用了 esm 是不会自动注入这个变量的。
在 commonjs 中,注入了 __dirname , __filename , module , exports , require 五个内置变量用于实现导入导出的能力。而在 esm 中实现方式是不一样的。
在 esm 中,显然模块的导入导出使用 export/import ,自然不会再用 exports/require ,同理 __dirname , __filename 也有对应的写法。
方法一
首先,使用 node:url 模块中的URL和 fileURLToPath 函数对URL进行解析和转换。
然后,使用URL构造函数的第一个参数传入".",即当前目录的相对路径,再结合 import.meta.url 来获取当前目录的URL。
最后,使用 fileURLToPath 函数将URL转换为文件路径,从而获取所需的 __dirname
// 方法一
import { URL, fileURLToPath } from "node:url";
// 获取__filename
function getCurrnetFile () {
return fileURLToPath(import.meta.url);
}
// 获取__dirname
function getCurrnetDir () {
const url = new URL(".", import.meta.url);
return fileURLToPath(url);
}方法二
这种方法使用了 node:path 模块中的 dirname 函数和 node:url 模块中的 fileURLToPath 函数。
首先,使用 fileURLToPath 函数将 import.meta.url 转换为文件路径,获取当前文件的路径 __filename 。
然后,使用 dirname 函数将文件路径转换为所在目录的路径 __dirname ,从而得到了 __dirname 。
// 方法二
import { dirname } from "node:path";
import { fileURLToPath } from "node:url";
// 获取__filename
function getCurrnetFile () {
return fileURLToPath(import.meta.url);
}
// 获取__dirname
function getCurrnetDir () {
const __filename = fileURLToPath(import.meta.url);
const __dirname = dirname(__filename);
return __dirname;
}可以看到使用了一个关键API import.meta.url ,其实 import.meta 是 ECMA 规范的一部分:
The import.meta object exposes context-specific metadata to a JavaScript module.
It contains information about the module, like the module’s URL.
言下之意, import.meta 提供了一个模块的上下文信息。
总之,以上两种方法都是在ESM中模拟获取 __dirname 的功能。
它们利用 import.meta.url 获取模块的URL,然后使用相关的Node.js内置模块对URL或文件路径进行解析,从而得到当前模块所在的目录路径
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Vue API中setup ref reactive函数使用教程
setup是用来写组合式api,内部的数据和方法需要通过return之后,模板才能使用。在之前vue2中,data返回的数据,可以直接进行双向绑定使用,如果我们把setup中数据类型直接双向绑定,发现变量并不能实时响应。接下来就详细看看它们的使用2022-12-12
vue2 前后端分离项目ajax跨域session问题解决方法
本篇文章主要介绍了vue2 前后端分离项目ajax跨域session问题解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-04-04
vue3+vite多项目多模块打包(基于vite-plugin-html插件)
这篇文章主要给大家介绍了关于vue3+vite基于vite-plugin-html插件实现多项目多模块打包的相关资料,现在很多小伙伴都已经使用Vite+Vue3开发项目了,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2023-07-07


最新评论