作者:KDDA_ 链接:https://juejin.cn/post/6955736879106883597
背景
我们常常会遇到一个问题,网上现有的开源插件并不能满足我们实际项目的预期。但如果只需要对源码进行小小的改动就能满足我们的需求,那改源码一定是首选
前言
修改别人的源码往往有这几个方式:
- 直接在项目的node_modules下找到插件的源码直接修改;
- 优点:简单直接、快速见效
- 缺点:不能持久化,一旦重新安装就失效;不方便团队成员使用修改后的代码
- 去github上fork代码到自己的仓库进行修改,并将自己修改过后的代码发布到npm上使用;
- 优点:团队成员都可以使用到这份修改的代码
- 缺点:麻烦、十分麻烦
显而易见,上面这两种方法既不优雅,也不可靠。作为程序员的我们岂能被这事儿给难住,开源社区早已给我们准备好了解决方案:patch-package[1]
使用补丁
通过cra开启一个项目
代码语言:javascript复制npx create-react-app my-app
cd my-app
npm start
给项目@alifd/next(ui库)、patch-package、postinstall-postinstall(使用yarn安装时需要安装,npm无需安装此依赖)
代码语言:javascript复制yarn add @alifd/next patch-package postinstall-postinstall -D
给 package.json文件中添加脚本命令(非常重要,无论我们使用yarn还是npm,在整体安装结束后都会自动执行该命令,对node_modules中的包打补丁)
代码语言:javascript复制 "scripts": {
"postinstall": "patch-package"
}
我们引入组件button,并查看组件当前结构
situation.png
我们去node_module中修改button源码
revise.png
我们在看看页面情况(如果没有效果的话,可以重启一下服务 )
result.png
修改完并且也生效了,我们就要开始打补丁了,运行命令yarn patch-package package-name
yarn patch-package @alifd/next
成功后你会看到根目录多了一个patches文件夹,里面包含了你修改的npm包的patch文件。点开可以很清楚的看到你都做了哪些修改。文件名中的1.22.21就是依赖包的版本号,表示这个补丁只对1.22.21版本的插件生效
patch.png
测试
删除node_module并重新安装
代码语言:javascript复制rm -rf node_modules/ && yarn
依赖包安装完成后可以在命令行中看到补丁被应用(倒数后5行)
代码语言:javascript复制[1/4]