亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

node.js路徑處理方法以及絕對(duì)路徑詳解

 更新時(shí)間:2021年03月04日 17:37:24   作者:看風(fēng)景就  
這篇文章介紹的是nodejs路徑處理及絕對(duì)路徑以及一個(gè)Node.js獲取項(xiàng)目根目錄的小技巧,這個(gè)內(nèi)容非常實(shí)用。有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。

1. 路徑處理方法

__dirname     表示當(dāng)前文件所在的目錄的絕對(duì)路徑

__filename     表示當(dāng)前文件的絕對(duì)路徑

module.filename ==== __filename 等價(jià)

process.cwd()    返回運(yùn)行當(dāng)前腳本的工作目錄的路徑,一般情況下不變,在process.chdir()后,或者shelljs.cd切換目錄后會(huì)發(fā)生變化

process.chdir()   改變工作目錄

2. 絕對(duì)路徑

2.1  要獲取node項(xiàng)目的根路徑,可以使用 node-app-root-path 這個(gè)包

2.2  更好的寫絕對(duì)路徑的方式是使用best-require這個(gè)包

根目錄使用~

require('~/application/apis/controllers/posts');
require('~/application/apis/services/rest');
require('~/application/apis/config');

別名目錄使用:

//長(zhǎng)目錄設(shè)置別名
const ROOT_PATH = process.cwd();
require('best-require')(ROOT_PATH, {
 apis: ROOT_PATH + '/application/apis',
 controllers: ROOT_PATH + '/application/apis/controllers'
});
//使用別名更簡(jiǎn)潔
require(':controllers/posts');
require(':apis/services/rest');
require(':apis/config');

2.3 在全局變量上掛載路徑

//聲明
var path = require('path')
global.appRequire = function(path) {
 return require(path.resolve(__dirname, path))
}
//使用
var User = appRequire('app/model/User')

3. path.join和path.resolve的區(qū)別

3.1 path.join 是連接路徑,僅僅做路徑的連接

console.log(path.join(__dirname,'a','b')); // 假如當(dāng)前文件的路徑是E:/node/1,那么拼接出來(lái)就是E:/node/1/a/b。
console.log(path.join(__dirname,'/a','/b','..')); // 路徑開頭的/不會(huì)影響拼接,..代表上一級(jí)文件,拼接出來(lái)的結(jié)果是:E:/node/1/a
console.log(path.join(__dirname,'a',{},'b')); // 而且path.join()還會(huì)幫我們做路徑字符串的校驗(yàn),當(dāng)字符串不合法時(shí),會(huì)拋出錯(cuò)誤:Path must be a string.

3.2 path.resolve 是解析絕對(duì)路徑,將一個(gè)或多個(gè)連接后的路徑解析為絕對(duì)路徑,以應(yīng)用程序?yàn)楦夸?,普通字符串代表子目錄?代表絕對(duì)路徑根目錄

3.2.1 /作為根目錄,多個(gè)/開始的路徑,只有最后一個(gè)有效,前面的被忽略

path.resolve('/a', '/b') // '/b'

3.2.2 總是返回一個(gè)以相對(duì)于當(dāng)前的工作目錄(working directory)的絕對(duì)路徑

path.resolve('./a', './b') // '/Users/username/Projects/webpack-demo/a/b'

3.2.3 path.resolve()方法是以程序?yàn)楦夸洠鳛槠瘘c(diǎn),根據(jù)參數(shù)解析出一個(gè)絕對(duì)路徑

console.log(path.resolve()); // 得到應(yīng)用程序啟動(dòng)文件的目錄(得到當(dāng)前執(zhí)行文件絕對(duì)路徑) E:\zf\webpack\1\src
console.log(path.resolve('a','/c')); // E:/c 因?yàn)?斜杠代表根目錄,所以得到的就是E:/c
console.log(path.resolve(__dirname,'img/so')); // E:\zf\webpack\1\src\img\so 這個(gè)就是將文件路徑拼接,并不管這個(gè)路徑是否真實(shí)存在。
console.log(path.resolve('wwwroot', 'static_files/png/', '../gif/image.gif')) // E:\zf\webpack\1\src\wwwroot\static_files\gif\image.gif

附Node.js獲取項(xiàng)目根目錄的小技巧

大家都知道node.js只提供了一個(gè) dirname全局變量,通過(guò) dirname可以獲得“C:\wwwroot\yidata\server”。

這時(shí)需要用到path。

import path from 'path'; (ES6)或var path = require
(
 'path '
);
path.join(dirname,'../')

即可獲取到node.js的項(xiàng)目根目錄。

path.join(dirname,'../app/img/favicon.ico')

即可獲取目標(biāo)文件。

總結(jié)

到此這篇關(guān)于node.js路徑處理方法以及絕對(duì)路徑的文章就介紹到這了,更多相關(guān)nodejs路徑處理及絕對(duì)路徑內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • NodeJs實(shí)現(xiàn)定時(shí)任務(wù)的示例代碼

    NodeJs實(shí)現(xiàn)定時(shí)任務(wù)的示例代碼

    本篇文章主要介紹了NodeJs實(shí)現(xiàn)定時(shí)任務(wù)的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • Nodejs實(shí)現(xiàn)的一個(gè)簡(jiǎn)單udp廣播服務(wù)器、客戶端

    Nodejs實(shí)現(xiàn)的一個(gè)簡(jiǎn)單udp廣播服務(wù)器、客戶端

    這篇文章主要介紹了Nodejs實(shí)現(xiàn)的一個(gè)簡(jiǎn)單udp廣播服務(wù)器、客戶端,本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2014-09-09
  • nodejs URL模塊操作URL相關(guān)方法介紹

    nodejs URL模塊操作URL相關(guān)方法介紹

    這篇文章主要介紹了nodejs URL模塊操作URL相關(guān)方法介紹,本文講解了parse方法、format方法、querystring方法等,需要的朋友可以參考下
    2015-03-03
  • node之本地服務(wù)器圖片上傳的方法示例

    node之本地服務(wù)器圖片上傳的方法示例

    這篇文章主要介紹了node之本地服務(wù)器圖片上傳的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-03-03
  • 搭建pomelo 開發(fā)環(huán)境

    搭建pomelo 開發(fā)環(huán)境

    Pomelo是基于 Node.js 的高性能、分布式游戲服務(wù)器框架。它包括基礎(chǔ)的開發(fā)框架和相關(guān)的擴(kuò)展組件(庫(kù)和工具包),可以幫助你省去游戲開發(fā)枯燥中的重復(fù)勞動(dòng)和底層邏輯的開發(fā)。Pomelo不但適用于游戲服務(wù)器開發(fā),也可用于開發(fā)高實(shí)時(shí) Web 應(yīng)用
    2014-06-06
  • node+multer實(shí)現(xiàn)圖片上傳的示例代碼

    node+multer實(shí)現(xiàn)圖片上傳的示例代碼

    這篇文章主要介紹了node+multer實(shí)現(xiàn)圖片上傳的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • node+koa實(shí)現(xiàn)數(shù)據(jù)mock接口的方法

    node+koa實(shí)現(xiàn)數(shù)據(jù)mock接口的方法

    本篇文章主要介紹了node+koa實(shí)現(xiàn)數(shù)據(jù)mock接口的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • 快速使用node.js進(jìn)行web開發(fā)詳解

    快速使用node.js進(jìn)行web開發(fā)詳解

    本篇文章主要介紹了快速使用node.js進(jìn)行web開發(fā)詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-04-04
  • nodejs+mongodb+vue前后臺(tái)配置ueditor的示例代碼

    nodejs+mongodb+vue前后臺(tái)配置ueditor的示例代碼

    本篇文章主要介紹了nodejs+mongodb+vue前后臺(tái)配置ueditor的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01
  • node.js Promise對(duì)象的使用方法實(shí)例分析

    node.js Promise對(duì)象的使用方法實(shí)例分析

    這篇文章主要介紹了node.js Promise對(duì)象的使用方法,結(jié)合實(shí)例形式分析了node.js中Promise對(duì)象的功能、定義、調(diào)用方法及相關(guān)使用技巧,需要的朋友可以參考下
    2019-12-12

最新評(píng)論