• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > node_modules中如何优雅的修改依赖库?方法介绍

node_modules中如何优雅的修改依赖库?方法介绍

作者:站长图库 字体:[增加 减小] 来源:互联网 时间:2022-04-29

站长图库向大家介绍了node_modules,修改依赖库等相关知识,希望对您有所帮助

node项目中如何优雅的修改node_modules的依赖库?下面本篇文章就来带大家优雅修改node_modules中依赖库的方法,希望对大家有所帮助!


node_modules中如何优雅的修改依赖库?方法介绍


最近使用了公司内的一个开源项目,由于业务需要(不适合提MR的业务修改),需要简单的修改 @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包你就会发现是你修改后的结果


node_modules中如何优雅的修改依赖库?方法介绍


最后,这个库的官网还有一段很详细的对比,描述了什么时候用patch什么时候fork,描述的非常到位:


node_modules中如何优雅的修改依赖库?方法介绍



分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • node_modules中如何优雅的修改依赖库?方法介绍

相关文章

  • 2022-04-29Thinkphp中JS如何获取模板变量(示例详解)
  • 2022-04-29趣味讲解Node.js中的回调函数(附示例)
  • 2022-04-29php htmlentities 乱码怎么办
  • 2022-04-29Photoshop制作梦幻效果的光圈教程
  • 2022-04-29PHP怎么去掉字符串两边的指定字符
  • 2022-04-29Photoshop制作时尚绚丽的3D立体字教程
  • 2022-04-29Photoshop制作漂亮的钢板字
  • 2022-04-29PhotoShop制作蓝色梦幻动漫签名溶图教程
  • 2022-04-29PHP如何实现获取验证码
  • 2022-04-29Photoshop鼠绘杯子教程

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • FCKeditor安装FLV视频插件,适用所有CMS
    • 解决Laravel 8 undefined variable错误问题
    • PhotoShop简单制作面条艺术字体效果设计教程
    • JavaScript中解析parseInt()的怪异行为
    • Javascript如何获取用户输入的值
    • AI制作超强立体效果
    • Nodejs中如何定义全局变量
    • 谈谈PHP运算符“::”、“->”和“=>”的区别
    • 简单的提高seo排名的方法:依靠数量庞大的反向
    • Photoshop通过图层样式制作各式各样的按钮

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有