patch-package 修改 node_modules流程以及注意点

patch-package 是 前端工程里非常常用的一个工具 ,用来 给 node_modules 里的第三方依赖打补丁(打 patch) ,并且 可被 Git 管理、可复现 。本质:diff + apply

一句话理解:

当你不得不改 npm 包源码,但又不想 fork / 不想每次重装都手动改时,用 patch-package。


使用流程:

第一步:安装补丁工具

bash 复制代码
npm install patch-package postinstall-postinstall --save-dev 

这会自动在你的 package.json 的 scripts 里加上 "postinstall": "patch-package",确保每次安装依赖都自动修复。如果没自动加入,请手动加上。

第二步:直接修改 node_modules/某个包 的源码,并运行 patch-package 包名生成补丁

bash 复制代码
npx patch-package 你的包名

# 注意:npx patch-package 后面写的是:你"修改的那个 npm 包的包名(package name)",不是文件名,也不是路径。

例如我这里修改的文件是NativeVosk.ts 文件,生成补丁的命令应该为:npx patch-package react-native-vosk

运行后,你会发现项目根目录多了一个 patches 文件夹,里面有一个 "你修改的包名"+x.x.x.patch 文件。提交代码时把这个文件也提交上去。

第三步:清理旧的构建缓存并运行

如果是普通的项目,直接删除node_modules,再执行npm i 即可。

如果是React Native 等复杂项目,需要再删除原生项目生成的android / ios 文件夹、编译缓存 (android/app/build 或 Gradle 缓存),命令如下(这里等待时间会比较长):

bash 复制代码
# 如果是React Native 项目,先执行
cd android && ./gradlew clean && cd ..

# 再重新生成原生目录
npx expo prebuild --clean

# 最后运行
npx expo run:android

最后:验证

patch 内容是否包含你的改动

随便打开 patch 文件,确认有你改的 diff

相关推荐
jiayong2317 小时前
前端面试题库 - Vue框架篇
前端·vue.js·面试
孟陬17 小时前
一个小小 alias,提升开发幸福感
前端·后端·命令行
Hello--_--World17 小时前
为什么 用vite进行分包后,可以通过 浏览器强制缓存 提高性能?路由懒加载进行的分包与 vite进行的分包有什么不同?
前端·javascript·缓存·vite
三*一17 小时前
Mapbox GL JS 前端多边形分割实战:从踩坑到优雅实现
开发语言·前端·javascript·vue.js
环信即时通讯云17 小时前
环信回调服务本地开发指南:基于Node.js的Webhook测试方案
node.js
秋収冬藏17 小时前
第一章:Dify 整体架构总览
前端
时光不负努力17 小时前
阶段 6:前端工程体系 - 企业级落地
前端
KaMeidebaby17 小时前
卡梅德生物技术快报|多肽库筛选技术构建药物递送功能肽库:流程、算法与质控体
前端·数据库·其他·百度·新浪微博
李剑一17 小时前
字节一面,考察的够全面的啊!面试官:请分阶段解释一下从输入URL到页面渲染整个链路中的关键环节和可观测点
前端
xChive17 小时前
前端请求取消:用 AbortController 从 fetch 到 axios
前端·vue.js·axios·fetch·abortcontroller