如何修改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就失效了,建议锁定该包的版本;
  • 如果对组件修改的内容较多,不建议使用这个;
相关推荐
深念Y1 天前
我明白为什么B站没法在浏览器开直播了——Windows Chrome推流踩坑全记录
前端·chrome·webrtc·浏览器·srs·直播·flv
zhangxingchao1 天前
AI应用开发七:可以替代 RAG 的技术
前端·人工智能·后端
Sun@happy1 天前
现代 Web 前端渗透——基础篇(1)
前端·web安全
希冀1231 天前
【CSS学习第十一篇】
前端·css·学习
隔窗听雨眠1 天前
doctype、charset、meta如何控制整个渲染流水线
java·服务器·前端
kyriewen1 天前
写组件文档写到吐?我用AI自动生成Storybook,同事以后直接抄
前端·javascript·面试
excel1 天前
🧠 Prisma 表名大写 vs SQL 导出小写问题深度解析(附踩坑与解决方案)
前端·后端
周淳APP1 天前
【前端工程化原理通识:从源头到运行时的理论阐述】
前端·编译·打包·前端工程化
五点六六六1 天前
你敢信这是非Native页面写出来的渐变效果吗🌝(底层原理解析
前端·javascript·面试
tedcloud1231 天前
TradingAgents部署教程:打造AI量化分析工作流
服务器·前端·人工智能·系统架构·edge