您好,登录后才能下订单哦!
这篇文章主要讲解了“node_modules中怎么修改依赖库”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“node_modules中怎么修改依赖库”吧!
需要简单的修改 @tencent/wuji-server-lite的源码,package.json如下:
"dependencies": { "@tencent/taf-config": "^2.0.4", "@tencent/wuji-server-lite": "2.0.30", "patch-package": "^6.2.0" }
一般我们有两种做法:
方法一:把修改后的代码换个名字重新打个包提交到tnpm,然后直接引用这个新包
方法二:把代码copy移出node_modules作为本地依赖
无论是上面哪种办法,作为有代码洁癖的人来说,都觉得很别扭,我就改了某一个文件了一两行代码,却要如此臃肿的copy整个项目,更要命的是最后可能都忘了自己修改了哪里,没有diff可供追溯。
我当时就咨询了几个nodejs-er,在我没使用nodejs的这一两年时间内,nodejs是不是已经提供了什么高大上的方法解决了这个问题,比如可以指定node_modules中的某个文件被本地的另外一个替换?得到的答案是 no。
顿时我就萌生出了要自己弄一个解决这类问题的npm包,然后又按常例的事先google了一番,结果却发现已经存在了这么一个东东,叫patch-package(https://www.npmjs.com/package/patch-package),一看发布时间是两年前,如果我没中途去做吃鸡手游,也许这个库最先可能是被我弄出来的,哈哈。
既然不需要我再造一个轮子了,那接下来我就分享下怎么使用吧。
1、本地安装,npm i patch-package
2、在package.json 的scripts中加入 { "postinstall": "patch-package" },这是npm的一个钩子,会在依赖包被install之后执行
3、修改node_modules中的代码
4、生成patches,npx patch-package your-package-name
5、提交patches后,重新install包你就会发现是你修改后的结果
最后,这个库的官网还有一段很详细的对比,描述了什么时候用patch什么时候fork,描述的非常到位:
感谢各位的阅读,以上就是“node_modules中怎么修改依赖库”的内容了,经过本文的学习后,相信大家对node_modules中怎么修改依赖库这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。