欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決vite.config.js無法使用__dirname的問題

 更新時間:2023年10月09日 17:13:28   作者:fly丶知秋  
這篇文章主要介紹了解決vite.config.js無法使用__dirname的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

vite.config.js無法使用__dirname

__dirname commonjs 規(guī)范的內(nèi)置變量。

如果使用了 esm 是不會自動注入這個變量的。

commonjs 中,注入了 __dirname , __filename , module , exports , require 五個內(nèi)置變量用于實現(xiàn)導(dǎo)入導(dǎo)出的能力。而在 esm 中實現(xiàn)方式是不一樣的。

esm 中,顯然模塊的導(dǎo)入導(dǎo)出使用 export/import ,自然不會再用 exports/require ,同理 __dirname __filename 也有對應(yīng)的寫法。

方法一

首先,使用 node:url 模塊中的URL和 fileURLToPath 函數(shù)對URL進(jìn)行解析和轉(zhuǎn)換。

然后,使用URL構(gòu)造函數(shù)的第一個參數(shù)傳入".",即當(dāng)前目錄的相對路徑,再結(jié)合 import.meta.url 來獲取當(dāng)前目錄的URL。

最后,使用 fileURLToPath 函數(shù)將URL轉(zhuǎn)換為文件路徑,從而獲取所需的 __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 函數(shù)和 node:url 模塊中的 fileURLToPath 函數(shù)。

首先,使用 fileURLToPath 函數(shù)將 import.meta.url 轉(zhuǎn)換為文件路徑,獲取當(dāng)前文件的路徑 __filename 。

然后,使用 dirname 函數(shù)將文件路徑轉(zhuǎn)換為所在目錄的路徑 __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;
}

可以看到使用了一個關(guān)鍵API import.meta.url ,其實 import.meta ECMA 規(guī)范的一部分:

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,然后使用相關(guān)的Node.js內(nèi)置模塊對URL或文件路徑進(jìn)行解析,從而得到當(dāng)前模塊所在的目錄路徑

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • VUE使用vuex解決模塊間傳值問題的方法

    VUE使用vuex解決模塊間傳值問題的方法

    本篇文章主要介紹了VUE使用vuex解決模塊間傳值問題 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • Vue組件設(shè)計之多列表拖拽交換排序功能實現(xiàn)

    Vue組件設(shè)計之多列表拖拽交換排序功能實現(xiàn)

    這篇文章主要介紹了Vue組件設(shè)計之多列表拖拽交換排序,常見的場景有單列表拖拽排序,多列表拖拽交換排序,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05
  • Vue API中setup ref reactive函數(shù)使用教程

    Vue API中setup ref reactive函數(shù)使用教程

    setup是用來寫組合式api,內(nèi)部的數(shù)據(jù)和方法需要通過return之后,模板才能使用。在之前vue2中,data返回的數(shù)據(jù),可以直接進(jìn)行雙向綁定使用,如果我們把setup中數(shù)據(jù)類型直接雙向綁定,發(fā)現(xiàn)變量并不能實時響應(yīng)。接下來就詳細(xì)看看它們的使用
    2022-12-12
  • vue中的數(shù)據(jù)綁定原理的實現(xiàn)

    vue中的數(shù)據(jù)綁定原理的實現(xiàn)

    本篇文章主要介紹了vue中的數(shù)據(jù)綁定原理的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • vue2 前后端分離項目ajax跨域session問題解決方法

    vue2 前后端分離項目ajax跨域session問題解決方法

    本篇文章主要介紹了vue2 前后端分離項目ajax跨域session問題解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • Vue element-admin權(quán)限控制之按鈕使用

    Vue element-admin權(quán)限控制之按鈕使用

    這篇文章主要介紹了Vue element-admin權(quán)限控制之按鈕使用,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • vue3+vite多項目多模塊打包(基于vite-plugin-html插件)

    vue3+vite多項目多模塊打包(基于vite-plugin-html插件)

    這篇文章主要給大家介紹了關(guān)于vue3+vite基于vite-plugin-html插件實現(xiàn)多項目多模塊打包的相關(guān)資料,現(xiàn)在很多小伙伴都已經(jīng)使用Vite+Vue3開發(fā)項目了,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • VUE中如何實現(xiàn)阻止事件冒泡

    VUE中如何實現(xiàn)阻止事件冒泡

    這篇文章主要介紹了VUE中如何實現(xiàn)阻止事件冒泡,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue3中watchEffect的用途淺析

    Vue3中watchEffect的用途淺析

    這篇文章主要給大家介紹了關(guān)于Vue3中watchEffect用途的相關(guān)資料, watch和watchEffect都是監(jiān)聽器,但在寫法和使用上有所區(qū)別,本文進(jìn)行了詳細(xì)的介紹,需要的朋友可以參考下
    2021-07-07
  • Vue.js實現(xiàn)文件上傳壓縮優(yōu)化處理技巧

    Vue.js實現(xiàn)文件上傳壓縮優(yōu)化處理技巧

    這篇文章主要介紹了Vue.js實現(xiàn)文件上傳壓縮優(yōu)化處理,本文給大家介紹兩種方法一種是借助canvas的封裝的文件壓縮上傳,二是使用compressorjs第三方插件實現(xiàn),本文給大家介紹的非常詳細(xì)需要的朋友可以參考下
    2022-11-11

最新評論