如何修改node_modules的组件不被install替换?可以使用patch-package

修改 node_modules 中的组件代码存在一个天然问题:当执行 npm installyarn install 时,依赖会被重新安装,手动修改的代码会被覆盖。要解决这个问题,可以使用 patch-package 生成补丁的方式。

patch-package 能将对 node_modules 的修改生成补丁文件,并在依赖安装后自动应用补丁,确保修改不会丢失。

使用方法:

1.安装 patch-package
lua 复制代码
npm install patch-package --save-dev
# 或 yarn add patch-package --dev
2.修改 node_modules 中组件的代码

直接找到需要修改的文件(如 node_modules/xxx/xxx.vue),按需求修改。

3. 生成补丁文件

执行命令生成补丁(xxx 是你修改的包的名名称,如:uv-view):

go 复制代码
npx patch-package xxx

此时项目根目录会生成 patches/xxx+版本号.patch 文件,记录你的修改内容。

4.配置自动应用补丁

package.jsonscripts 中添加:

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

postinstall不用刻意执行,每次执行 npm install 后,会自动运行 patch-package,将补丁应用到 node_modules 中。

5.注意事项
  • 如何修改的包升级了,那么你写patch就失效了,建议锁定该包的版本;
  • 如果对组件修改的内容较多,不建议使用这个;
相关推荐
风止何安啊2 小时前
收到字节的短信:Trae SOLO上线了?尝尝鲜,浅浅做个音乐播放器
前端·html·trae
抱琴_2 小时前
大屏性能优化终极方案:请求合并+智能缓存双剑合璧
前端·javascript
用户463989754322 小时前
Harmony os——长时任务(Continuous Task,ArkTS)
前端
fruge2 小时前
低版本浏览器兼容方案:IE11 适配 ES6 语法与 CSS 新特性
前端·css·es6
颜酱3 小时前
开发工具链-构建、测试、代码质量校验常用包的比较
前端·javascript·node.js
颜酱3 小时前
package.json 配置指南
前端·javascript·node.js
todoitbo3 小时前
基于 DevUI MateChat 搭建前端编程学习智能助手:从痛点到解决方案
前端·学习·ai·状态模式·devui·matechat
oden4 小时前
SEO听不懂?看完这篇你明天就能优化网站了
前端
IT_陈寒4 小时前
React性能优化:这5个Hooks技巧让我减少了40%的重新渲染
前端·人工智能·后端
Sunhen_Qiletian4 小时前
《Python开发之语言基础》第六集:操作文件
前端·数据库·python