React Native 中给第三方库打补丁

有时使用了某个第三方库,可是它有些问题,我们不得不修改它的源码。

我们可能不方便给原作者提 Pull Request,因为他们可能不愿意接受我们的更改。又或者原作者无法及时发布新版本。

种种原因,我们只有去修改 node_modules 目录下的文件。

可是当我们执行 yarn installyarn add 时,原先的修改会丢失。

有没有办法让我们可以在 yarn installyarn add 时,自动把修改的源码加载进来?

推荐使用 patch-packageopen

安装

复制代码
yarn add patch-package postinstall-postinstall

大多数时候,当你执行 yarn addyarn removeyarn install时,Yarn 会用原始的模块完全取代你的 node_modules 的内容。 patch-package 使用 postinstall 钩子按照你的要求来修改这些原始模块。

Yarn 只在 yarn installyarn add 之后运行 postinstall 钩子,但不包括在 yarn remove 之后。postinstall-postinstall 包用来确保你的 postinstall 钩子在 yarn remove 后也能被执行。

配置 scripts,确保每次执行 yarn install 或者 yarn add 之后,都会自动执行 patch-package

复制代码
// package.json
"scripts": {
    "postinstall": "patch-package",
}

使用

首先对你的 node_modules 文件夹中的某个包的文件进行修改,例如js文件注释或者改动。运行

复制代码
yarn patch-package react-native-system-setting

会在根目录下,创建了一个 patches 文件夹,里面有一个补丁文件,记录你的修改。

这样就不怕在更新的时候,修改丢失了。

相关推荐
GUIQU.19 分钟前
【JavaScript】ES6+ 新特性
前端·javascript·es6
安小牛23 分钟前
Kotlin 学习--数组
javascript·学习·kotlin
getapi2 小时前
Flutter 强制横屏
前端·javascript·flutter
白嫖一茶2 小时前
QQ风格客服聊天窗口
javascript·css·css3
纪元A梦3 小时前
华为OD机试真题——天然蓄水库(2025A卷:200分)Java/python/JavaScript/C++/C语言/GO六种最佳实现
java·c语言·javascript·c++·python·华为od·go
枫super3 小时前
Day-03 前端 Web-Vue & Axios 基础
前端·javascript·vue.js
zhangbao90s4 小时前
Tauri 与 Electron 对比:性能、包大小及实际权衡
javascript·node.js
你的人类朋友4 小时前
飞速入门 Axon:Node.js 微服务的轻量级选择
javascript·后端·node.js
Moment5 小时前
拆包的艺术:Webpack SplitChunksPlugin 执行流程全流程揭秘 🤩🤩🤩
前端·javascript·webpack
那小孩儿5 小时前
最简单的new Date()展示,也能做优化
前端·javascript·性能优化