本篇內(nèi)容介紹了“node中的path模塊和fs模塊怎么用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供建甌網(wǎng)站建設、建甌做網(wǎng)站、建甌網(wǎng)站設計、建甌網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、建甌企業(yè)網(wǎng)站模板建站服務,十年建甌做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。
path模塊用于對路徑和文件進行處理,提供了很多方法。
有一個需求是將路徑和文件名進行拼接。
const basePath = '/user/why' const filename = 'abc.txt'
那么有人會使用字符串拼接的方式進行拼接。
const filePath = basePath + '/' + filename console.log(filePath);
這樣的結(jié)果雖然沒有問題,但是考慮到不同的系統(tǒng),windows系統(tǒng)可以使用\或者\\或者/作為路徑分隔符,而Mac OS、Linux的Unix操作系統(tǒng)使用/作為路徑分隔符。
解決上述問題,我們可以使用path.resolve來進行路徑的拼接。
const path = require('path') const basePath = '/user/why' const filename = 'abc.txt' const filePath = path.resolve(basePath, filename) console.log(filePath);
dirname:獲取文件的父文件夾
basename:獲取文件名
extname:獲取文件擴展名
const path = require('path') const filePath = '/User/haha/abc.txt' console.log(path.dirname(filePath)); console.log(path.basename(filePath)); console.log(path.extname(filePath));
如果我們想要把多個路徑進行拼接,但是不同的操作系統(tǒng)可能使用不同的分隔符,我們可以使用path.join函數(shù)。
const path = require('path') const basepath = '/User/haha' const filename = 'abc.txt' const filePath = path.join(basepath, filename) console.log(filePath);
如果我們想要將某個文件和文件夾拼接,可以使用path.resolve。
const basepath = 'User/haha' const filename = 'abc.txt'
path.resolve和path.join一樣也可以進行路徑的拼接,那么它們的區(qū)別是什么呢?
const basepath = '../User/haha' const filename = './abc.txt' const othername = './haha.js' const filePath2 = path.join(basepath, filename, othername) console.log(filePath2); const filePath3 = path.resolve(basepath, filename, othername) console.log(filePath3);
我們可以看到它們的差別。
nodejs文件系統(tǒng)的API大都提供三種操作方式:
同步操作文件:代碼會被阻塞,不會繼續(xù)執(zhí)行
異步回調(diào)函數(shù)操作文件:代碼不會被阻塞,需要傳入回調(diào)函數(shù),當獲取到結(jié)果時,回調(diào)函數(shù)執(zhí)行
異步Promise操作文件:代碼不會被阻塞,通過fs.promises調(diào)用方法操作,會返回一個Promise,可以通過then、catch進行處理。
方式一 同步操作:fs.statSync
const fs = require('fs') const filepath = './abc.txt' const info = fs.statSync(filepath) console.log('后續(xù)需要執(zhí)行的代碼'); console.log(info);
方式二 異步操作
fs.stat(filepath, (err, info) => { if(err) { console.log(err); return } console.log(info); console.log(info.isFile()); // 判斷是否是一個文件 console.log(info.isDirectory()); // 判斷是否是一個文件夾 }) console.log('后續(xù)需要執(zhí)行的代碼');
方式三: Promise
fs.promises.stat(filepath).then(info => { console.log(info); }).catch(err => { console.log(err); }) console.log('后續(xù)需要執(zhí)行的代碼');
node為所有打開的文件分配了一個數(shù)字型的文件描述符。所有文件系統(tǒng)操作都使用這些文件描述符來標識和跟蹤每個特定的文件。
fs.open()方法用于分配新的文件描述符fd。一旦被分配,則文件描述符可用于從文件讀取數(shù)據(jù)、向文件寫入數(shù)據(jù)、或請求關于文件的信息。
const fs = require('fs') fs.open('./abc.txt', (err, fd) => { if(err) { console.log(err); return } // 通過文件描述符去獲取文件信息 fs.fstat(fd, (err, info) => { console.log(info); }) })
fs.readFile(path[, options], callback):讀取文件內(nèi)容
fs.writeFile(path[, options], callback):往文件中寫入內(nèi)容
option參數(shù):
flag: 寫入的方式
encoding:字符的編碼
文件的寫入
fs.writeFile('./abc.txt', content, {flag: "a"}, err => { console.log(err); })
文件的讀取
fs.readFile('./abc.txt', (err, data) => { console.log(data); })
如果不填寫encoding,返回的結(jié)果Buffer(二進制)。
fs.readFile('./abc.txt', {encoding: 'utf-8'}, (err, data) => { console.log(data); })
使用fs.mkdir()或者fs.mkdirSync創(chuàng)建一個新的文件夾。
const fs = require('fs') // 創(chuàng)建文件夾 const dirname = './haha' if(!fs.existsSync(dirname)) { fs.mkdir(dirname, (err) => { console.log(err); }) }
fs.readdir
fs.readdir(dirname, (err, files) => { console.log(files); })
獲取文件夾中的所有文件,此時目錄如下圖所示,可以使用遞歸。
const fs = require('fs') const path = require('path') const dirname = './haha' function getFiles(dirname) { fs.readdir(dirname, {withFileTypes: true}, (err, files) => { // console.log(files); for(let file of files) { // 判斷是否是文件夾 if(file.isDirectory()) { const filepath = path.resolve(dirname, file.name) getFiles(filepath) } else { console.log(file.name); } } }) } getFiles(dirname)
可以使用fs.rename對文件夾進行重命名。
fs.rename('./haha', './xixi', err => { console.log(err); })
“node中的path模塊和fs模塊怎么用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!