node.js路徑處理方法以及絕對(duì)路徑詳解
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)文章希望大家以后多多支持腳本之家!
- 獲取本機(jī)IP地址的實(shí)例(JavaScript / Node.js)
- 詳解Node.js access_token的獲取、存儲(chǔ)及更新
- Node.js獲取前端ajax提交的request信息
- node.js從數(shù)據(jù)庫(kù)獲取數(shù)據(jù)
- node.js解決獲取圖片真實(shí)文件類型的問題
- node.js+Ajax實(shí)現(xiàn)獲取HTTP服務(wù)器返回?cái)?shù)據(jù)
- 使用node.js 獲取客戶端信息代碼分享
- node.js正則表達(dá)式獲取網(wǎng)頁(yè)中所有鏈接的代碼實(shí)例
- Node.js和PHP根據(jù)ip獲取地理位置的方法
- 詳解Nodejs get獲取遠(yuǎn)程服務(wù)器接口數(shù)據(jù)
相關(guān)文章
NodeJs實(shí)現(xiàn)定時(shí)任務(wù)的示例代碼
本篇文章主要介紹了NodeJs實(shí)現(xiàn)定時(shí)任務(wù)的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-12-12Nodejs實(shí)現(xiàn)的一個(gè)簡(jiǎn)單udp廣播服務(wù)器、客戶端
這篇文章主要介紹了Nodejs實(shí)現(xiàn)的一個(gè)簡(jiǎn)單udp廣播服務(wù)器、客戶端,本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下2014-09-09node+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-02node+koa實(shí)現(xiàn)數(shù)據(jù)mock接口的方法
本篇文章主要介紹了node+koa實(shí)現(xiàn)數(shù)據(jù)mock接口的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09nodejs+mongodb+vue前后臺(tái)配置ueditor的示例代碼
本篇文章主要介紹了nodejs+mongodb+vue前后臺(tái)配置ueditor的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01node.js Promise對(duì)象的使用方法實(shí)例分析
這篇文章主要介紹了node.js Promise對(duì)象的使用方法,結(jié)合實(shí)例形式分析了node.js中Promise對(duì)象的功能、定義、調(diào)用方法及相關(guān)使用技巧,需要的朋友可以參考下2019-12-12