站長資訊網
最全最豐富的資訊網站

技巧分享:優雅的獲取 package.json 文件

技巧分享:優雅的獲取 package.json 文件

前端(vue)入門到精通課程:進入學習
API 文檔、設計、調試、自動化測試一體化協作工具:點擊使用

日常開發中我們都知道package.json是對項目或者模塊包的描述,里面包含許多元信息,那么應該如何讀取package.json獲取里面的信息呢?發揮作用的就是咱們今天的主角——read-pkg,關鍵源碼只有30行左右,接下來就一起細看一下實現,也算是為后續開發自己的工具包奠定基礎!【相關教程推薦:nodejs視頻教程】

收獲清單

  • 調試源碼
  • 優雅的獲取package.json
  • 規范包元數據
  • import.meta.url的應用

學前準備

下載源碼

git clone https://github.com/sindresorhus/read-pkg.git cd read-pkg&&yarn
登錄后復制

一般源碼學習先看README.md和package.json,readme教用法,package.json則會注明命令,一般我們調試也是從package.json的script入手,甩個截圖:

技巧分享:優雅的獲取 package.json 文件

這命令第一次見可能不知道它想表達啥,再往下看devDependencies就可以知道三個命令分別對應三個包,不知道包干嘛的?自行百度去,一般包的用法都能在npm上搜到

技巧分享:優雅的獲取 package.json 文件

  • ava
node.js測試包

技巧分享:優雅的獲取 package.json 文件

  • tsd
檢測ts類型

技巧分享:優雅的獲取 package.json 文件

  • xo
(ESLint包裝器),具有很好的默認值

技巧分享:優雅的獲取 package.json 文件

源碼調試分析

提前在入口文件打好斷點,然后點package.json的script中的調試腳本按鈕開啟調試,如果沒有這個按鈕,則可能需要更新vscode。

技巧分享:優雅的獲取 package.json 文件

源碼結構分析

  • 引入依賴

// node進程 import process from 'node:process'; // fs文件模塊 import fs, {promises as fsPromises} from 'node:fs'; // path 路徑模塊 import path from 'node:path'; // url模塊 import {fileURLToPath} from 'node:url'; // 解析json,并且會伴隨有用的報錯,https://github.com/sindresorhus/parse-json#readme import parseJson from 'parse-json'; // 規范化包元數據 https://github.com/npm/normalize-package-data#readme import normalizePackageData from 'normalize-package-data';
登錄后復制

  • 將url轉化為文件路徑

// fileURLToPath將url轉化為文件路徑 const toPath = urlOrPath => urlOrPath instanceof URL ? fileURLToPath(urlOrPath) : urlOrPath;
登錄后復制

隨著調試來到了test文件,有幾個概念在很多源碼中都會看到,因此值得我們關注一下,下面分別解析:

技巧分享:優雅的獲取 package.json 文件

import.meta.url

主要是應用于__filename和__dirname在ES模塊不可用

技巧分享:優雅的獲取 package.json 文件

path.dirname

用于獲取指定路徑的目錄名稱

fileURLToPath(import.meta.url)

提取路徑

process.chdir

更改Node.js進程的當前工作目錄,或者在執行失敗時拋出異常(例如,如果指定的目錄不存在)。

技巧分享:優雅的獲取 package.json 文件

  • readPackage方法(異步讀取)

export async function readPackage({cwd, normalize = true} = {}) { // 默認用process.cwd獲取當前工作目錄,獲取工作目錄     cwd = toPath(cwd) || process.cwd(); // 獲取package.json相對當前工作目錄的絕對路徑     const filePath = path.resolve(cwd, 'package.json'); // 異步讀取package.json并解析,fsPromises異步文件模塊     const json = parseJson(await fsPromises.readFile(filePath, 'utf8'));    // 規范化包元數據     if (normalize) {         normalizePackageData(json);     }       return json;  }
登錄后復制

  • readPackageSync方法(同步讀?。?/li>

export function readPackageSync({cwd, normalize = true} = {}) {    // 默認用process.cwd獲取當前工作目錄,獲取工作目錄     cwd = toPath(cwd) || process.cwd();    // 獲取package.json相對當前工作目錄的絕對路徑     const filePath = path.resolve(cwd, 'package.json');    // 讀取package.json并解析     const json = parseJson(fs.readFileSync(filePath, 'utf8'));      // 序列化元數據     if (normalize) {          normalizePackageData(json);      }       return json;  }
登錄后復制

  • normalizePackageData作用
序列化前

技巧分享:優雅的獲取 package.json 文件

序列化后

技巧分享:優雅的獲取 package.json 文件

調試后發現序列化后會生成_id,對應測試用例中的t.truthy(package_._id)

總結

今天下載并調試了read-pkg的源碼,進一步了解了nodejs的path、url、process模塊對于讀取文件的應用,read-pkg麻雀雖小五臟俱全,完整的測試用例也是我們可以在自己的工具包中借鑒使用的!今天剛好是國慶,追夢人們國慶快樂哇~

贊(0)
分享到: 更多 (0)
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
91麻豆精品国产| www.99精品| 伦精品一区二区三区视频| 无码国产精品一区二区免费3p| 精品人妻V?出轨中文字幕| 精品日韩一区二区| 日韩精品视频在线观看免费 | 国产高清在线精品一区| 亚洲自偷自偷精品| 亚洲国产另类久久久精品| 97久久国产露脸精品国产| 精品视频一区二区三区四区五区| 无码日韩人妻精品久久| 日韩精品国产自在久久现线拍| 国产精品午夜无码av体验区| 精品久久久久久久免费人妻| 国产微拍精品一区二区| 亚洲国产精品无码久久| 国产综合色香蕉精品五月婷| 78成人精品电影在线播放日韩精品电影一区亚洲 | 人人妻人人澡人人爽人人精品97| 国产精品无码AV一区二区三区| 国产一区二区精品久久岳| 久久人搡人人玩人妻精品首页| 国产日韩久久久精品影院首页 | 久久精品九九亚洲精品| 99精品国产在热久久婷婷| 久久99国产精品| 无码精品久久久久久人妻中字 | 中日韩精品无码一区二区三区| 国产精品久久久久久福利69堂| 精品国产伦一区二区三区在线观看 | 欧美日韩精品一区二区在线观看| 无码精品尤物一区二区三区 | 亚洲午夜精品一区二区公牛电影院| 99久久精品美女高潮喷水| 99精品视频在线观看免费专区 | 中文字幕日韩一区二区三区不| 八区精品色欲人妻综合网| 日韩人妻无码一区二区三区 | 亚洲av成人无码久久精品 |