前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Node如何获取pnpm安装的包源码真实代码路径并操作

Node如何获取pnpm安装的包源码真实代码路径并操作

作者头像
CRPER
发布2022-09-19 15:39:44
1.4K0
发布2022-09-19 15:39:44
举报
文章被收录于专栏:CRPER折腾记CRPER折腾记

前言

在改造老工程的包依赖管理的时候,有时候我们想引入一些社区比较好用的包管理; 有时候一些阻塞点会阻拦我们,特别我们构建流程可能会拷贝node_modules包源码的行为;

举个研发例子

不同公司的CLI因为面对的业务场景和构建场景不一样,有些时候,我们会做一些差异化的特性, 比如工程前端CLI有暴露代码映射拷贝行为,就是打包的时候会把node_modules下的某些包的资源拷贝到特定路径,用于后续其他处理

代码语言:javascript
复制
// 本地调试 editor 时需要打开以下配置
  copy: {
    // editor source reference
    'dist/libs/ckeditor': 'node_modules/xxxx-editor/dist',
  },

npm安装的目录结构是固定的,包名+源文件 ,所以寻址是固定的

在这里插入图片描述
在这里插入图片描述

问题聚焦

当我们想用pnpm这类的时候,安装的node_modules目录结构就是有他们自己的一些特性,而不是一个常规npm生成的node_modules结构

pnpm 默认创建了一个非平铺的 node_modules,因此代码无法访问任意包

如图所示:

在这里插入图片描述
在这里插入图片描述

这种包名加版本号的,就没法作为一个固定规律寻址了。因为存在可变性! 那么我们实在要搞,有木有法子?

姿势

node里面有一个api [require.resolve]很实用,刚好解决了我们这个场景; 它可以返回require包的绝对路径【基于package.json的入口字段】

demo

在我的一个本地工程内,采用pnpm安装依赖,输出的绝对路径可以寻址到源码

代码语言:javascript
复制
console.log(require.resolve('yaml'));
console.log(require.resolve('axios'));

// /Users/code/engineering-tools/node_modules/.pnpm/yaml@2.1.1/node_modules/yaml/dist/index.js
// /Users/code/engineering-tools/node_modules/.pnpm/axios@0.21.4/node_modules/axios/index.js
在这里插入图片描述
在这里插入图片描述

那么怎么适配我们之前的配置文件呢?

代码语言:javascript
复制
// 本地调试 editor 时需要打开以下配置
  copy: {
    // editor source reference
    'dist/libs/ckeditor': require.resolve('xxxx-editor'),
  },

这时候CLI运行态的时候就可以动态检测到这个模块的绝对路径,拿到了绝对路径。 接下来想拷贝什么就很方便做到了~

总结

有不对之处请留言,会及时修正,谢谢阅读

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-08-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 举个研发例子
  • 问题聚焦
  • 姿势
    • demo
    • 总结
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档