久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      node中的fs模塊是什么

      在node中,fs模塊指的是“文件系統(tǒng)模塊”,是用來操作文件的模塊。fs模塊的API大都提供三種操作方式:1、同步操作文件:代碼會(huì)被阻塞,不會(huì)繼續(xù)執(zhí)行;2、異步回調(diào)函數(shù)操作文件:代碼不會(huì)被阻塞,需要傳入回調(diào)函數(shù),當(dāng)獲取到結(jié)果時(shí),回調(diào)函數(shù)執(zhí)行;3、異步Promise操作文件:代碼不會(huì)被阻塞,通過fs.promises調(diào)用方法操作,會(huì)返回一個(gè)Promise。

      node中的fs模塊是什么

      本教程操作環(huán)境:windows7系統(tǒng)、nodejs16版,DELL G3電腦。

      文件系統(tǒng)模塊(簡稱 fs)允許我們?cè)L問計(jì)算機(jī)上的文件系統(tǒng)并與之交互。

      fs 模塊是 Node.js 官方提供的、用來操作文件的模塊。它提供了一系列的方法和屬性,用來滿足用戶對(duì)文件的操作需求。

      • fs.readFile() 方法,用來讀取指定文件中的內(nèi)容

      • fs.writeFile() 方法,用來向指定的文件中寫入內(nèi)容 如果要在 JavaScript 代碼中

      如何使用 fs

      文件系統(tǒng)模塊是一個(gè)核心的 Node.js 模塊。這意味著我們不必安裝它。我們唯一需要做的就是將 fs 模塊導(dǎo)入到自己的文件中。

      因此,在文件頂部添加:

      const fs = require('fs')

      現(xiàn)在,我們可以使用前綴 fs 從文件系統(tǒng)模塊調(diào)用任何方法。

      或者,我們可以只從 fs API 導(dǎo)入所需的方法,如下所示:

      const { writeFile, readFile } = require('fs')

      注意:為了方便起見,我們還需要導(dǎo)入 path 模塊。它是另一個(gè)核心 Node.js 模塊,它允許我們使用文件和目錄路徑。

      導(dǎo)入 fs 模塊后,在文件中添加:

      const path = require('path')

      使用文件系統(tǒng)模塊時(shí),path 模塊不是必需的。但它對(duì)我們有很大的幫助!

      同步與異步

      fs模塊的文件操作一般支持同步和異步兩種API,異步又包括了回調(diào)函數(shù)和promsie的形式。同步一般后面帶sync字樣。

      fs模塊的API大都提供三種操作方式:

      • 同步操作文件:代碼會(huì)被阻塞,不會(huì)繼續(xù)執(zhí)行

      • 異步回調(diào)函數(shù)操作文件:代碼不會(huì)被阻塞,需要傳入回調(diào)函數(shù),當(dāng)獲取到結(jié)果時(shí),回調(diào)函數(shù)執(zhí)行

      • 異步Promise操作文件:代碼不會(huì)被阻塞,通過fs.promises調(diào)用方法操作,會(huì)返回一個(gè)Promise,可以通過then、catch進(jìn)行處理。

      需要注意的是,默認(rèn)情況下,所有 fs 方法都是異步的。但是,我們可以通過在方法末尾添加 Sync 來使用同步版本。

      例如,writeFile 方法的同步版本為 writeFileSync。同步方法將同步的完成代碼,因此它們阻塞了主線程。阻塞 Node.js 中的主線程被認(rèn)為是不好的做法,我們不應(yīng)該這么做。

      因此,以下我們都將使用文件系統(tǒng)模塊中的異步方法。

      寫入文件

      要從 Node.js 應(yīng)用程序?qū)懭胛募?,?qǐng)使用 writeFile 方法。

      writeFile 方法至少接受以下參數(shù):

      • 文件名
      • 內(nèi)容
      • 回調(diào)

      如果指定的文件已經(jīng)存在,它會(huì)將舊內(nèi)容替換為您作為參數(shù)提供的內(nèi)容。如果指定的文件不存在,則創(chuàng)建一個(gè)新文件。

      導(dǎo)入 fspath 模塊后,在文件中編寫以下代碼:

      fs.writeFile('content.txt', 'All work and no play makes Jack a dull boy!', err => {   if (err) throw err    process.stdout.write('創(chuàng)建成功!') })

      上面的代碼將創(chuàng)建了一個(gè)名為 content.txt 的新文件,并添加了文本 All work and no play makes Jack a dull boy! 作為內(nèi)容。如果存在任何錯(cuò)誤,回調(diào)函數(shù)將拋出該錯(cuò)誤。否則,它將向控制臺(tái)輸出文件創(chuàng)建成功。

      writeFile 還有其他變體,例如:

      • fs.writeFileSync — 同步寫入文件
      • fsPromises.writeFile — 使用基于 Promise 的 API 寫入文件

      查看此要點(diǎn):https://gist.github.com/catalinpit/571ba06c06214b5c8744036c6500af92

      從文件中讀取

      在讀取文件之前,需要?jiǎng)?chuàng)建并存儲(chǔ)文件的路徑。path 模塊的路徑在這里很方便。

      使用 join 模塊中的 path 方法,您可以創(chuàng)建文件路徑,如下所示:

      const filePath = path.join(process.cwd(), 'content.txt')

      第一個(gè)參數(shù) process.cwd() 返回當(dāng)前工作目錄。現(xiàn)在您已經(jīng)有了文件路徑,可以讀取文件的內(nèi)容了。

      在文件中編寫以下代碼:

      fs.readFile(filePath, (error, content) => {   if (error) throw error    process.stdout.write(content) })

      readFile 方法至少接受兩個(gè)參數(shù):

      • 文件的路徑
      • 回調(diào)

      如果有錯(cuò)誤,它會(huì)拋出一個(gè)錯(cuò)誤。否則,它會(huì)在終端中輸出文件內(nèi)容。

      readFile 還有其他變體,例如:

      • fs.readFileSync — 同步寫入文件
      • fsPromises.readFile — 使用基于 Promise 的 API 寫入文件

      查看此要點(diǎn):https://gist.github.com/catalinpit/badc2a539a44412892a0e05a9575d54d

      讀取目錄的內(nèi)容

      在目錄中顯示文件與讀取文件內(nèi)容非常相似。但是,不是傳遞文件路徑,而是傳遞當(dāng)前工作目錄(我們可以傳遞任何其他目錄)。

      然后,傳遞一個(gè)回調(diào)函數(shù)來處理響應(yīng)。在文件中編寫以下代碼:

      fs.readdir(process.cwd(), (error, files) => {   if (error) throw error    console.log(files) })

      到目前為止,我們只使用 process.stdout.write 將內(nèi)容輸出到終端。但是,您可以簡單地使用 console.log,就像上面的代碼片段一樣。

      如果運(yùn)行該應(yīng)用程序,我們應(yīng)該會(huì)得到一個(gè)包含目錄中所有文件的數(shù)組。

      查看此要點(diǎn):https://gist.github.com/catalinpit/f82c4e6ae3acd5d97efdecb0bc67979e

      刪除文件

      文件系統(tǒng)模塊有一種方法,允許您刪除文件。但是,需要注意的是,它只適用于文件,不適用于目錄。

      當(dāng)以文件路徑作為參數(shù)調(diào)用 unlink 方法時(shí),它將刪除該文件。將以下代碼段添加到文件中:

      fs.unlink(filePath, error => {   if (error) throw error    console.log('文件已刪除!') })

      如果您重新運(yùn)行代碼,您的文件將被刪除!

      查看此要點(diǎn):https://gist.github.com/catalinpit/b1201434218c400f77e042109bfce99e

      創(chuàng)建目錄

      我們可以使用 mkdir 方法異步創(chuàng)建目錄。在文件中編寫以下代碼:

      fs.mkdir(`${process.cwd()}/myFolder/secondFolder`, { recursive: true }, (err) => {   if (err) throw err    console.log('已成功創(chuàng)建文件夾!') })

      首先,要在當(dāng)前工作目錄中創(chuàng)建一個(gè)新文件夾。如前所述,您可以使用 cwd() 方法從 process 對(duì)象獲取當(dāng)前工作目錄。

      然后,傳遞要?jiǎng)?chuàng)建的一個(gè)或多個(gè)文件夾。但是,這并不意味著您必須在當(dāng)前工作目錄中創(chuàng)建新文件夾。你可以在任何地方創(chuàng)建它們。

      現(xiàn)在,第二個(gè)參數(shù)是遞歸選項(xiàng)。如果未將其設(shè)置為 true,則無法創(chuàng)建多個(gè)文件夾。如果將 recursive 選項(xiàng)設(shè)置為 false,上述代碼將給出一個(gè)錯(cuò)誤。試試看!

      但是,如果您只想創(chuàng)建一個(gè)文件夾,則無需將 recursive 選項(xiàng)設(shè)置為 true

      以下代碼可以正常工作!

      fs.mkdir(`${process.cwd()}/myFolder`, err => {   if (err) throw err    console.log('已成功創(chuàng)建文件夾!') });

      因此,我想強(qiáng)調(diào)使用 recursive。如果要在文件夾中創(chuàng)建文件夾,則需要將其設(shè)置為 true。它將創(chuàng)建所有文件夾,即使它們不存在。

      另一方面,如果您只想創(chuàng)建一個(gè)文件夾,可以將其保留為 false。

      查看此要點(diǎn):https://gist.github.com/catalinpit/09bad802541102c0cce2a2e4c3985066

      刪除目錄

      刪除目錄的邏輯類似于創(chuàng)建目錄。如果您查看為創(chuàng)建目錄而編寫的代碼和下面的代碼,您會(huì)發(fā)現(xiàn)相似之處。

      因此,在文件中編寫以下代碼:

      fs.rmdir(`${process.cwd()}/myFolder/`, { recursive: true }, err => {   if (err) throw err    console.log('已成功刪除文件夾!') })

      使用文件系統(tǒng)模塊中的 rmdir 方法,并傳遞以下參數(shù):

      • 要?jiǎng)h除的目錄
      • 遞歸屬性
      • 回調(diào)

      如果將 recursive 屬性設(shè)置為 true,它將刪除文件夾及其內(nèi)容。請(qǐng)務(wù)必注意,如果文件夾中包含內(nèi)容,則需要將其設(shè)置為 true。否則,您將得到一個(gè)錯(cuò)誤。

      以下代碼段僅在文件夾為空時(shí)有效:

      fs.rmdir(`${process.cwd()}/myFolder/`, err => {   if (err) throw err    console.log('已成功刪除文件夾!') })

      如果 myFolder 中有其他文件和/或文件夾,如果未傳遞 { recursive: true },則會(huì)出現(xiàn)錯(cuò)誤。

      知道何時(shí)使用 recursive 選項(xiàng)以及何時(shí)不避免問題是很重要的。

      查看此要點(diǎn):https://gist.github.com/catalinpit/a8cb6aca75cef8d6ac5043eae9ba22ce

      目錄/文件重命名

      使用 fs 模塊,您可以重命名目錄和文件。下面的代碼片段顯示了如何使用 rename 方法進(jìn)行此操作。

      // 重命名一個(gè)目錄fs.rename(`${process.cwd()}/myFolder/secondFolder`, `${process.cwd()}/myFolder/newFolder`, err => {   if (err) throw err    console.log('目錄重命名!') });// 重命名一個(gè)文件fs.rename(`${process.cwd()}/content.txt`, `${process.cwd()}/newFile.txt`, err => {   if (err) throw err    console.log('文件重命名!') });

      rename 方法包含三個(gè)參數(shù):

      • 第一個(gè)參數(shù)是現(xiàn)有的文件夾/文件
      • 第二個(gè)參數(shù)是新名稱
      • 回調(diào)

      因此,要重命名文件或目錄,我們需要傳遞當(dāng)前文件/目錄的名稱和新名稱。運(yùn)行應(yīng)用程序后,應(yīng)更新目錄/文件的名稱。

      需要注意的是,如果新路徑已經(jīng)存在(例如,文件/文件夾的新名稱),它將被覆蓋。因此,請(qǐng)確保不要錯(cuò)誤地覆蓋現(xiàn)有文件/文件夾。

      查看此要點(diǎn):https://gist.github.com/catalinpit/5c3e7c6ae39d09996ff67175a719122e

      向文件中添加內(nèi)容

      我們還可以使用 appendFile 方法向現(xiàn)有文件添加新內(nèi)容。

      如果比較 writeFileappendFile 這兩種方法,我們可以發(fā)現(xiàn)它們是相似的。傳遞文件路徑、內(nèi)容和回調(diào)。

      fs.appendFile(filePath, 'nAll work and no play makes Jack a dull boy!', err => {   if (err) throw err      console.log('All work and no play makes Jack a dull boy!') })

      上面的代碼片段演示了如何向現(xiàn)有文件添加新內(nèi)容。如果運(yùn)行應(yīng)用程序并打開文件,您應(yīng)該會(huì)看到其中的新內(nèi)容。

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)