技巧分享:优雅的获取 package.json 文件

技巧分享:优雅的获取 package.json 文件

日常开发中我们都知道package.json是对项目或者模块包的描述,里面包含许多元信息,那么应该如何读取package.json获取里面的信息呢?发挥作用的就是咱们今天的主角——read-pkg,关键源码只有30行左右,接下来就一起细看一下实现,也算是为后续开发自己的工具包奠定基础!【相关教程推荐:read-pkg】

收获清单

调试源码优雅的获取package.json规范包元数据import.meta.url的应用

学前准备

下载源码

git clone https://github.com/sindresorhus/read-pkg.gitcd read-pkg&&yarn

登录后复制

    一般源码学习先看read-pkg和read-pkg,readme教用法,package.json则会注明命令,一般我们调试也是从package.json的script入手,甩个截图:

1.png

    这命令第一次见可能不知道它想表达啥,再往下看devDependencies就可以知道三个命令分别对应三个包,不知道包干嘛的?自行百度去,一般包的用法都能在read-pkg上搜到

2.png

read-pkg

node.js测试包

3.png

read-pkg

检测ts类型

4.png

read-pkg

(ESLint包装器),具有很好的默认值

5.png

源码调试分析

    提前在入口文件打好断点,然后点package.json的script中的调试脚本按钮开启调试,如果没有这个按钮,则可能需要更新vscode。

6.png

源码结构分析

引入依赖

// 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#readmeimport parseJson from 'parse-json';// 规范化包元数据 https://github.com/npm/normalize-package-data#readmeimport normalizePackageData from 'normalize-package-data';

登录后复制将url转化为文件路径

// fileURLToPath将url转化为文件路径const toPath = urlOrPath => urlOrPath instanceof URL ? fileURLToPath(urlOrPath) : urlOrPath;

登录后复制

    随着调试来到了test文件,有几个概念在很多源码中都会看到,因此值得我们关注一下,下面分别解析:

7.png

read-pkg

    主要是应用于__filename和__dirname在ES模块不可用

8.png

read-pkg

    用于获取指定路径的目录名称

fileURLToPath(import.meta.url)

    提取路径

read-pkg

    更改Node.js进程的当前工作目录,或者在执行失败时抛出异常(例如,如果指定的目录不存在)。

9.png

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方法(同步读取)

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作用

序列化前

10.png

序列化后

11.png

    调试后发现序列化后会生成_id,对应测试用例中的t.truthy(package_._id)

总结

    今天下载并调试了read-pkg的源码,进一步了解了nodejs的path、url、process模块对于读取文件的应用,read-pkg麻雀虽小五脏俱全,完整的测试用例也是我们可以在自己的工具包中借鉴使用的!今天刚好是国庆,追梦人们国庆快乐哇~

更多node相关知识,请访问:read-pkg!

以上就是技巧分享:优雅的获取 package.json 文件的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2698265.html

(0)
上一篇 2025年3月7日 18:48:30
下一篇 2025年3月7日 18:48:40

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论