解决vite.config.js无法使用__dirname的问题

 更新时间:2023年10月09日 17:13:28   作者:fly丶知秋  
这篇文章主要介绍了解决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如何引用public中的js文件

    Vue如何引用public中的js文件

    这篇文章主要介绍了Vue如何引用public中的js文件,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • Vue build过程取消console debugger控制台信息输出方法详解

    Vue build过程取消console debugger控制台信息输出方法详解

    这篇文章主要为大家介绍了Vue build过程取消console debugger控制台信息输出方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • 分享Vue组件传值的几种常用方式(二)

    分享Vue组件传值的几种常用方式(二)

    这篇文章主要介绍了分享Vue组件传值的几种常用方式,文章围绕主题斩开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • vue项目中如何调用多个不同的ip接口

    vue项目中如何调用多个不同的ip接口

    这篇文章主要介绍了vue项目中如何调用多个不同的ip接口,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • Vue3和Electron实现桌面端应用详解

    Vue3和Electron实现桌面端应用详解

    本文主要介绍了Vue3和Electron实现桌面端应用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-07-07
  • vue如何使用pdf.js实现在线查看pdf文件功能

    vue如何使用pdf.js实现在线查看pdf文件功能

    PDF.js是一个开源的JavaScript库,用于在网页上渲染和显示PDF文件,在Vue中使用PDF.js来预览PDF文件是很常见的需求,这篇文章主要给大家介绍了关于vue如何使用pdf.js实现在线查看pdf文件功能的相关资料,需要的朋友可以参考下
    2024-03-03
  • vue3中storeToRefs让store中的结构出来的数据也能变成响应式(推荐)

    vue3中storeToRefs让store中的结构出来的数据也能变成响应式(推荐)

    这篇文章主要介绍了vue3中storeToRefs让store中的结构出来的数据也能变成响应式,本文通过实例代码给大家介绍的分需要的朋友可以参考下
    2024-09-09
  • vue项目打包后网页的title乱码解决方案

    vue项目打包后网页的title乱码解决方案

    这篇文章主要介绍了vue项目打包后网页的title乱码解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • vue 倒计时结束跳转页面实现代码

    vue 倒计时结束跳转页面实现代码

    在商场大家经常看到停车收费倒计时支付页面,今天小编通过本文给大家分享vue 倒计时结束跳转页面功能,感兴趣的朋友一起看看吧
    2023-10-10
  • Vue引入ElementUI并使用的详细过程

    Vue引入ElementUI并使用的详细过程

    Element UI是一个基于Vue 2.0的桌面端组件库,旨在构建简洁、快速的用户界面,这篇文章主要介绍了Vue如何引入ElementUI并使用,需要的朋友可以参考下
    2024-06-06

最新评论