一文詳解nodejs的path模塊使用
前言
path 模塊是 nodejs 中用于處理文件/目錄路徑的一個內(nèi)置模塊,可以看作是一個工具箱,提供諸多方法供我們使用,當(dāng)然都是和路徑處理有關(guān)的。同時在前端開發(fā)中 path 模塊出現(xiàn)的頻率也是比較高的,比如配置 webpack 的時候等。本文是對該模塊中一些常用的方法進(jìn)行介紹,走,一起學(xué)習(xí)下吧。
- 需要注意下,nodejs 中所有的模塊(內(nèi)置,自定義)都需要使用 requier 進(jìn)行導(dǎo)入,一般導(dǎo)入位置在文件頂部。
const path = require('path');
API
basename (獲取路徑基礎(chǔ)名)
path.basename(path[,ext])
- path:文件/目錄路徑
- ext:(可選)文件擴(kuò)展名 例如 .js .css 等
- 返回值:path 路徑的最后一部分
注意:
- 如果 path 不是字符串或者給定的 ext 參數(shù)不是字符串,則拋出 TypeError
- 如果有 ext 參數(shù),當(dāng) ext 后綴名與文件名匹配上時返回的文件名會省略文件后綴
- 如果 path 尾部有目錄分隔符則會被忽略
const path = require("path"); path.basename('./ext/test.js') //test.js path.basename('./ext/test.js','.js') //test (當(dāng)后綴名與文件名匹配上時返回的文件名會省略文件后綴) path.basename('./ext/test.js','.html') //test.js (沒有匹配上時返回文件全名) path.basename('./ext/foo/') // foo (尾部目錄分隔符被忽略)
dirname (獲取路徑目錄名)
path.dirname(path)
- path:文件/目錄路徑
- 返回值:path 路徑的目錄名
注意:
- 如果 path 不是字符串,則拋出 TypeError
- 如果 path 尾部有目錄分隔符則會被忽略
const path = require("path"); path.dirname('./foo/bar/baz'); //./foo/bar (相對路徑/絕對路徑均可) path.dirname('/foo/bar/baz/'); // /foo/bar (尾部目錄分隔符被忽略) path.dirname('/foo/bar/baz/test.js'); // /foo/bar/baz
extname (獲取路徑擴(kuò)展名)
path.extname(path)
- path:文件/目錄路徑
- 返回值:path 路徑的擴(kuò)展名,從最后一次出現(xiàn) '.' 字符到 path 最后一部分的字符串結(jié)束,無擴(kuò)展名則返回空
注意:
如果 path 不是字符串,則拋出 TypeError
const path = require("path"); path.extname('foo/bar/baz/test.js'); // .js path.extname('foo/bar/baz');// '' (無擴(kuò)展名返回 '') path.extname('foo/bar/baz/.'); // '' path.extname('foo/bar/baz/test.'); // '.' path.extname('foo/bar/baz/.test'); // '' path.extname('foo/bar/baz/.test.js'); // '.js'
parse (解析路徑)
path.parse(path) ( str => obj )
path:文件/目錄路徑
返回值:帶有屬性(dir,root,base,name,ext)的對象
- root:根目錄
- dir: 文件所在的文件夾
- base:完整文件 ( index.js )
- name:文件名
- ext: 文件后綴名
注意:
- 如果 path 不是字符串,則拋出 TypeError
- 如果尾部有目錄分隔符則會被忽略
一圖勝千言
┌──────────────────┬────────────┐ │ dir │ base │ ├──────┬ ├──────┬─────┤ │ root │ │ name │ ext │ " / foo/bar/baz/ index .js "
const path = require("path"); path.parse('/foo/bar/baz/index.js') // { // root: '/', // dir: '/foo/bar/baz', // base: 'index.js', // ext: '.js', // name: 'index' // } path.parse('/foo/bar/baz') //尾部目錄分隔符省略 // { // root: '/', // dir: '/foo/bar', // base: 'baz', // ext: '', // name: 'baz' // } path.parse('./foo/bar/baz/index.js') //當(dāng)路徑為相對路徑 ./ 或../時 解析結(jié)果中root(代表根目錄,絕對路徑才有值)為 '' // { // root: '', // dir: './foo/bar/baz', // base: 'index.js', // ext: '.js', // name: 'index' // }
format (序列化路徑)
path.format(pathObj) 序列化 path 路徑,與 path.parse() 剛好相反
- pathObj:path對象
- 返回值:序列化后的字符串路徑 ( obj => string )
注意:
如果 pathObject 不是對象,則拋出 TypeError
pathObject 中的屬性需要注意優(yōu)先級:
- 當(dāng) dir 屬性存在則忽略 root 屬性
- 當(dāng) base 屬性存在則會忽略 name 和 ext 屬性
isAbsolute (是否是絕對路徑)
path.isAbsolute(path)
- path:文件/目錄路徑
- 返回值:true/false
注意:
- 如果 path 不是字符串,則拋出 TypeError
- 如果給定的 path 字符串長度為0,則返回 false
const path = require("path"); path.isAbsolute('//foo'); // true path.isAbsolute('\\\\foo'); // true path.isAbsolute('C:/foo/..'); // true path.isAbsolute('C:\\foo\\..'); // true path.isAbsolute('./bar\\baz'); // false path.isAbsolute('../bar/baz'); // false path.isAbsolute('.'); // false path.isAbsolute(''); // false
join(拼接路徑片段)
path.join([...paths])
- paths:路徑片段
- 返回值:使用平臺特定的分隔符作為定界符將所有給定的 path 片段連接在一起規(guī)范化后生成的路徑
注意:
- 如果 paths 不是字符串片段,則拋出 TypeError
- 零長度的 path 片段會被忽略
- 如果連接后的路徑字符長度為0,則返回 '.',表示當(dāng)前工作目錄
- 目錄分隔符有平臺差異,windows 返回為 ' \ '
const path = require("path"); path.join('') // '.' path.join('./') // '.\'path.join('../') // '..\'path.join('/foo/','bar','baz','../','index.js') // '\foo\bar\index.js'path.join('./bar','baz' ,'/','../','',index.js') // 'bar\index.js' path.join('foo', {}, 'bar'); // 'TypeError: Path must be a string. Received {}'
normalize(規(guī)范化路徑)
path.normalize(path)
- path: 文件/目錄路徑
- 返回值:規(guī)范后的路徑字符串
注意:
- 如果 path 不是字符串片段,則拋出 TypeError
- 尾部的分隔符會保留
- 如果 path字符串長度為0,則返回 '.',表示當(dāng)前工作目錄
- 路徑中的目錄分隔符均會被替換成平臺特定的目錄分隔符,windows 系統(tǒng) 會將 '/' 或'' 均替換成 ''
- 路徑中連續(xù)的多個分隔符會被規(guī)范化為一個
- 路徑中最好不要出現(xiàn)單個 ' \ ',因?yàn)楫?dāng)和字母在一起的時候會被當(dāng)做轉(zhuǎn)義符
const path = require("path"); path.normalize('') // '.'path.normalize('temp//foo//bar//..//'); // temp\foo\path.normalize('C:////temp\\\\/\\/\\/foo/bar') // C:\temp\foo\barpath.normalize('..////foo//\bar/baz/') // ..\fooar\baz\ (轉(zhuǎn)義字符出現(xiàn))path.normalize('temp//foo/\bar') // temp\fooar (轉(zhuǎn)義字符出現(xiàn))
relative(獲取 from 到 to 的相對路徑)
path.relative(from,to)
- from,to: 文件/目錄路徑
- 返回值:from 到 to 的相對路徑(to 相對于 form 的相對路徑)
注意:
- 如果 from 和 to 指向相同路徑相同 則返回 ''
- 如果 from 或 to 任何一方為空,則使用當(dāng)前工作目錄代替其空路徑
const path = require("path"); //當(dāng)前工作目錄為 \Stone\node\node\path_module path.relative('/foo/bar/baz','/foo/bar/dir/file.js') // ..\dir\file.js path.relative('/foo/bar/baz','/foo/bar/baz') // '' path.relative('/foo/bar/baz/files.js','') // ..\..\..\..\Stone\node\node\path_module path.relative('','/foo/bar/baz/files.js') // ..\..\..\..\foo\bar\baz\files.js path.relative('','./foo/bar/baz/files.js') // foo\bar\baz\files.js
這里針對 from 或 to 任何一方為空,則使用當(dāng)前工作目錄代替其空路徑。
稍作說明下,
例如當(dāng)前工作目錄為 \Stone\node\node\path_module
,則可以看到 path.relative('/foo/bar/baz/files.js','')
的輸出結(jié)果為..\..\..\..\Stone\node\node\path_module
,此時 to 為 \Stone\node\node\path_module
,
要輸出 to 相對于 from 的相對路徑,則 from 需要先 ../ 的形式 一層一層退出,來檢索與 to 的公共父級目錄,直到遇到公共父級目錄或者到根目錄停止,然后cd 進(jìn) to 目錄。這是針對另一方為絕對路徑,如果另一方為相對路徑,則直接就是當(dāng)前另一方路徑。
resolve(將路徑或路徑片段的序列解析為絕對路徑)
path.resolve([...paths])
- paths: 路徑或路徑片段的序列
- 返回值:路徑或路徑片段序列解析為絕對路徑。(將路徑片段解析后生成的絕對路徑)
注意:
- 路徑片段如果給出則必須是字符串類型,否則類型錯誤
- 給定的路徑序列從右到左進(jìn)行處理,每個后續(xù)的 path 前置,直到構(gòu)造出一個絕對路徑
- 如果處理完所有給定的 path 片段之后還未生成絕對路徑,則再加上當(dāng)前工作目錄
- 生成的路徑均已規(guī)范化,并且除非將路徑解析為根目錄,否則將刪除尾部斜杠
- 零長度的 path 片段會被忽略
- 若沒有傳入 path 片段,則 path.resolve() 將返回當(dāng)前工作目錄的絕對路徑
const path = require("path"); //當(dāng)前工作目錄為 \Stone\node\node\path_module path.resolve('/foo/bar', './baz'); // '/foo/bar/baz' path.resolve('/foo/bar','', '/tmp/file/'); //'/tmp/file' path.resolve('root', 'foo/baz/', '../fun/bar') // '\Stone\node\node\path_module\root\foo\fun\bar' path.resolve() // '\Stone\node\node\path_module'
path.resolve 方法解析路徑片段的時候會從右往左的順序依次解析,直到構(gòu)造出一個絕對路徑,否則會將當(dāng)前工作目錄加在路徑開頭。所以,通過 resolve 解析生成的路徑一定是絕對路徑。這個方法使用的非常多,應(yīng)該特眼熟,對,前端我們配置 webpack 的時候會高頻率用到,并且往往還會結(jié)合 __dirname
使用。
__dirname,__filename
- __dirname:可以看作是 nodejs 中的全局變量,它始終表示當(dāng)前執(zhí)行文件所在目錄的完整目錄名(絕對路徑)
- __filename:可以看作是 nodejs 中的全局變量,它始終表示當(dāng)前執(zhí)行文件的完整文件名(完整絕對路)
我們先在 path_module
目錄下運(yùn)行 node test.js
命令
<!--當(dāng)前執(zhí)行文件的完整路徑為\Stone\node\node\path_module\test.js--> const path = require("path"); console.log(__dirname); // \Stone\node\node\path_module console.log(__filename); // \Stone\node\node\path_module\test.js
然后我們在 \Stone\node\node
目錄下運(yùn)行 node path_module\test.js
,會發(fā)現(xiàn)輸出結(jié)果同上,
所以這就是說明 __dirname 和 __filename 始終跟當(dāng)前執(zhí)行文件有關(guān),跟啟動腳本所在目錄無關(guān)。
./ ../
./
和 ../
我們都知道是相對路徑的寫法,但是使用的過程中配合 require() 使用與否的結(jié)果是不同的。
- fs_module 目錄下 執(zhí)行 node test.js
<!--當(dāng)前啟動腳本的執(zhí)行命令所在目錄 \Stone\node\node\fs_module\test.js--> const fs = require('fs') fs.readFileSync('./ext/test1.js',(err,data)=> { console.log('ok') })
會正常打印出 ok
- \Stone\node\node 目錄下 執(zhí)行 node fs_module\test.js
<!--當(dāng)前啟動腳本的執(zhí)行命令所在目錄 \Stone\node\node--> const fs = require('fs') fs.readFile('./ext/test1.js',(err,data)=> { console.log('ok') })
運(yùn)行會報(bào)錯 no such file or directory, open './ext/test1.js'
這到底是為啥嘞,原因就是 './' 和 '../' 的路徑表示意義需要分情況,當(dāng)結(jié)合 require() 使用的時候相對于當(dāng)前執(zhí)行文件,如果不結(jié)合 require() 使用的情況下會相對于當(dāng)前啟動腳本的目錄,因此只有在 require() 時才使用相對路徑(./, ../) 的寫法,其他地方一律使用絕對路徑,這點(diǎn)一定要注意。
結(jié)語
關(guān)于nodejs path 模塊,我們今天就說到這里了,雖然 api 不是很多,但是 path 模塊在前端的使用頻率還是非常高的,所以覺得很值得學(xué)習(xí)了解一下的。
以上就是一文詳解nodejs的path模塊使用的詳細(xì)內(nèi)容,更多關(guān)于nodejs path模塊使用的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Nodejs進(jìn)階:express+session實(shí)現(xiàn)簡易登錄身份認(rèn)證
本篇文章主要介紹了Nodejs進(jìn)階:express+session實(shí)現(xiàn)簡易身份認(rèn)證示例,非常具有實(shí)用價值,需要的朋友可以參考下2017-04-04Node.js的HTTP模塊、URL模塊與supervisor工具介紹
這篇文章介紹了Node.js的HTTP模塊、URL模塊與supervisor工具,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06使用pm2部署node生產(chǎn)環(huán)境的方法步驟
這篇文章主要介紹了使用pm2部署node生產(chǎn)環(huán)境的方法步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-03-03在Debian(Raspberry Pi)樹莓派上安裝NodeJS的教程詳解
在樹莓派上運(yùn)行NodeJS并不需要特別的配置,你只需要確??梢杂胦penssh遠(yuǎn)程連接到你的樹莓派就ok了,關(guān)于在Debian(Raspberry Pi)樹莓派上安裝NodeJS的方法,大家可以通過本文了解下2017-09-09koa大型web項(xiàng)目中使用路由裝飾器的方法示例
這篇文章主要介紹了koa大型web項(xiàng)目中使用路由裝飾器的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Node做中轉(zhuǎn)服務(wù)器轉(zhuǎn)發(fā)接口
這篇文章主要介紹了Node做中轉(zhuǎn)服務(wù)器轉(zhuǎn)發(fā)接口的相關(guān)資料,需要的朋友可以參考下2017-10-10在Node.js中將SVG圖像轉(zhuǎn)換為PNG,JPEG,TIFF,WEBP和HEIF格式的方法
這篇文章主要介紹了在Node.js中將SVG圖像轉(zhuǎn)換為PNG,JPEG,TIFF,WEBP和HEIF格式的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08Node如何實(shí)現(xiàn)在瀏覽器預(yù)覽項(xiàng)目的所有圖片詳解
最近項(xiàng)目遇到了個需求,需要將存放圖片進(jìn)行預(yù)覽,所以這篇文章主要給大家介紹了關(guān)于Node如何實(shí)現(xiàn)在瀏覽器預(yù)覽項(xiàng)目的所有圖片的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01