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

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

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

vite.config.js無法使用__dirname

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

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

commonjs 中,注入了 __dirname __filename , module , exports , require 五個(gè)內(nèi)置變量用于實(shí)現(xiàn)導(dǎo)入導(dǎo)出的能力。而在 esm 中實(shí)現(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ù)的第一個(gè)參數(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;
}

可以看到使用了一個(gè)關(guān)鍵API import.meta.url ,其實(shí) 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 提供了一個(gè)模塊的上下文信息。

總之,以上兩種方法都是在ESM中模擬獲取 __dirname 的功能。

它們利用 import.meta.url 獲取模塊的URL,然后使用相關(guān)的Node.js內(nèi)置模塊對URL或文件路徑進(jìn)行解析,從而得到當(dāng)前模塊所在的目錄路徑

總結(jié)

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

相關(guān)文章

  • 詳解Vue.js之視圖和數(shù)據(jù)的雙向綁定(v-model)

    詳解Vue.js之視圖和數(shù)據(jù)的雙向綁定(v-model)

    本篇文章主要介紹了Vue.js之視圖和數(shù)據(jù)的雙向綁定(v-model),使用v-model指令,使得視圖和數(shù)據(jù)實(shí)現(xiàn)雙向綁定,有興趣的可以了解一下
    2017-06-06
  • vue.js入門教程之綁定class和style樣式

    vue.js入門教程之綁定class和style樣式

    小編之前介紹了通過vue.js計(jì)算屬性,不知道大家都學(xué)會了嗎。那這篇文章中我們將一起學(xué)習(xí)vue.js實(shí)現(xiàn)綁定class和style樣式,有需要的朋友們可以參考借鑒。
    2016-09-09
  • vue3+el-table封裝示例詳解(編輯、刪除、查看詳情按鈕一起封裝)

    vue3+el-table封裝示例詳解(編輯、刪除、查看詳情按鈕一起封裝)

    在Vue3中,利用Element?Plus?UI庫封裝表格組件,實(shí)現(xiàn)編輯、刪除和查看詳情的功能,通過定義tableData和tableDataHeader來管理表格數(shù)據(jù)和表頭,其中tableData通常從后端獲取,而tableHeader可根據(jù)具體需求自定義,感興趣的朋友跟隨小編一起看看吧
    2024-09-09
  • Vue如何清空對象

    Vue如何清空對象

    這篇文章主要介紹了Vue如何清空對象,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 解決vue中無法動態(tài)修改jqgrid組件 url地址的問題

    解決vue中無法動態(tài)修改jqgrid組件 url地址的問題

    下面小編就為大家分享一篇解決vue中無法動態(tài)修改jqgrid組件 url地址的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue3.0+vue-router+element-plus初實(shí)踐

    vue3.0+vue-router+element-plus初實(shí)踐

    這篇文章主要介紹了vue3.0+vue-router+element-plus初實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 淺談Vue-cli單文件組件引入less,sass,css樣式的不同方法

    淺談Vue-cli單文件組件引入less,sass,css樣式的不同方法

    下面小編就為大家分享一篇淺談Vue-cli單文件組件引入less,sass,css樣式的不同方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • 基于Vuejs框架實(shí)現(xiàn)翻頁組件

    基于Vuejs框架實(shí)現(xiàn)翻頁組件

    這篇文章主要為大家詳細(xì)介紹了基于VueJs框架的翻頁組件,小巧精致,性能優(yōu)異的MVVM框架實(shí)現(xiàn)翻頁組件,也適用于angular,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • Vue3?使用v-model實(shí)現(xiàn)父子組件通信的方法(常用在組件封裝規(guī)范中)

    Vue3?使用v-model實(shí)現(xiàn)父子組件通信的方法(常用在組件封裝規(guī)范中)

    這篇文章主要介紹了Vue3?使用v-model實(shí)現(xiàn)父子組件通信(常用在組件封裝規(guī)范中)的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-06-06
  • 在Vue3中使?echarts?圖表寬度自適應(yīng)變化的操作方法

    在Vue3中使?echarts?圖表寬度自適應(yīng)變化的操作方法

    本文介紹了在Vue3中使用ECharts時(shí),如何使圖表容器寬度自適應(yīng)頁面大小,通過修改模板中的div樣式,將寬度設(shè)置為100%,并監(jiān)聽窗口大小變化事件,調(diào)用ECharts實(shí)例的resize方法,實(shí)現(xiàn)圖表的自適應(yīng)調(diào)整,感興趣的朋友跟隨小編一起看看吧
    2025-02-02

最新評論