详细介绍:如何用 pnpm patch 给 element-plus 打补丁修复线上 bug(以 2.4.4 修复 PR#15197 为例)

news/2025/10/6 14:06:06/文章来源:https://www.cnblogs.com/ljbguanli/p/19127580

详细介绍:如何用 pnpm patch 给 element-plus 打补丁修复线上 bug(以 2.4.4 修复 PR#15197 为例)

背景

在实际项目开发中,依赖的三方库(如 element-plus)难免会遇到 bug。有时候官方虽然已经修复,但新版本升级成本高,或者有兼容性风险。这时,给依赖打补丁是最优雅的解决方案之一。

本文以 element-plus 2.4.4 为例,演示如何用 pnpm 的 patch 机制,优雅地修复 PR#15197 中的 bug,而无需升级到 2.5.0。


需求说明


方案选型

常见的依赖补丁方案有两种:

  1. patch-package
    适合 npm/yarn 用户,需手动维护 patch 文件和 postinstall 钩子。
  2. pnpm patch
    pnpm 官方支持,自动管理 patch 文件和依赖关系,推荐 pnpm 用户使用。

本文采用 pnpm patch 方案。


实操步骤

1. 生成 patch 编辑环境

在项目根目录执行:

pnpm patch element-plus

pnpm 会自动解压 element-plus 到 .pnpm_patched 目录,并用编辑器打开。


2. 修改源码

根据 PR#15197 的改动,找到:

分别做如下修改:

将:

const handleDatePick = (value, keepOpen
) =>
{

改为:

const handleDatePick =
async (value, keepOpen
) =>
{

并在:

if (props.type === 'datetime'
) {
handleFocusPicker(
)
}

之间插入:

if (props.type === 'datetime'
) {
await nextTick(
)
handleFocusPicker(
)
}

⚠️ 注意:element-plus 发布包通常有 lib/es/ 两套产物,都要 patch,否则有些构建工具(如 Vite)不会生效。


3. 保存并退出

保存所有修改,关闭编辑器。pnpm 会提示输入 patch message,随便写个描述,比如 fix: handleFocusPicker delay

pnpm 会自动生成 patches/element-plus.patch 文件,并在 package.json 里写入:

"pnpm": {
"patchedDependencies": {
"element-plus": "patches/element-plus.patch"
}
}

4. 应用 patch

##执行
pnpm install

pnpm 会自动应用 patch 文件到 node_modules。


5. 清理缓存,确保 patch 生效

Vite、Webpack 等现代构建工具有缓存,一定要清理缓存,否则 patch 可能不生效。

rm -rf node_modules/.vite dist .cache
pnpm install
pnpm run dev

6. 验证 patch 是否生效


常见问题与排查

  1. patch 文件没生效?

  2. 只 patch 了 lib 或 es 目录?

  3. pnpm 版本太低?

  4. 构建工具缓存?

  5. 实际用的不是 element-plus?


总结

pnpm patch 是现代前端项目修复三方依赖 bug 的利器。
只需几步,就能优雅地给依赖打补丁,既不影响升级,也方便团队协作和 CI/CD。

遇到类似问题,记得:

希望本文对你有帮助,欢迎点赞、收藏、评论交流!


参考资料:


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/929388.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

广州网站ui设计贵港免费的网站建设

我是个前端菜鸡,最近准备学习一点前端知识,先从Bootstrap5开始,毕竟早期Bootstrap还是比较火的。推出的Bootstrap5不再和jQery强制绑定,这里直接按照官方文档上来操作,打包工具我们选择Webpack。 一 前期准备 前期准备…

网站开发工具最好用做网站的工作量

https://blog.csdn.net/layman1024/article/details/72628379

Go 为何天生适合云原生? - 指南

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

ARC 207

目前打得最好的一集。 A 考虑如果 \(\le 0\) 还会减一,那么花掉的钱就是,\(1+2+\cdots +(n-1)\)。现在的问题就是,可能少花掉一些。 最多花掉 \(\mathcal{O}(n^2)\),所以考虑计数这个。发现其实,花掉的是 \(\sum_…

半年小结 Vol4. 跌跌撞撞开启 PhD 生涯

最近一直没能抽出时间总结于是半年总结一直拖拖拖,距离上次半年复盘已过了九个月,这九个月发生了很多:职业发展上经历了 idea 、实现、回片测试完整走完第一个加速器流片工作,切身体会了流片的血与泪; 第一次离开…

资源网站很难做做长图文网站

在c++中,一个文件调用另外一个文件最直接最快捷的方式就是#incldue<头文件>的使用,那么在元数据描述性语言QML中,如何从一个界面描述调用另外一个界面描述,一个.qml文件调用另外一个.qml呢?QML虽然有个import,但是用法可以说完全不同于#include。 引用方法1:直接…

大连可以做网站的公司北京公司注册最新政策

用Jsp Servlet和Jquery以及SQLServer实现商品管理系统。 采用MVC三层架构进行此程序的开发。 功能分析&#xff1a; 1.登录功能 2.查询和联合查询商品 3.增加商品 4.删除商品 效果演示 登录页面 查询页面 添加商品 点击删除 实现商品管理系统需要数据库和程序两部分。…

兰州网站建设推荐q479185700上快网站没排名怎么办

系列文章目录 C技能系列 Linux通信架构系列 C高性能优化编程系列 深入理解软件架构设计系列 高级C并发线程编程 设计模式系列 期待你的关注哦&#xff01;&#xff01;&#xff01; 现在的一切都是为将来的梦想编织翅膀&#xff0c;让梦想在现实中展翅高飞。 Now everythi…

深入解析:C++:内存管理

深入解析:C++:内存管理pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", &qu…

电商手机网站开发非国产手机浏览器

切洋葱时&#xff0c;由于洋葱有一种挥发物质&#xff0c;常使切菜的人流泪。防止的方法是&#xff1a; 1.在切洋葱前&#xff0c;把切菜刀在冷水中浸一会儿&#xff0c;再切时就不会因受挥发物质刺激而流泪了。 2.将洋葱对半切开后,先泡一下凉水再切,就不会流泪了. 3.放微波炉…

大数求余

大数求余问题: 在仅使用 int32 类型存储的前提下, 计算 \(x^a\ \text{mod}\ p\) (即 \(x^a\ \%\ p\)). 基本的运算规则: \((xy)\ \%\ p = [(x \ \% \ p)(y \ \% \ p)] \ \% \ p\) 循环求余 当 \(x < p\) 时, \[x^a …

网站开发需要研究什么门户网站 开发注意

vmware虚化优势VMWARE服务器虚拟化介绍利用虚拟化基础架构技术&#xff0c;可以不断整合工作负载&#xff0c;从而充分利用服务器并降低运营成本。该基础架构技术不但使系统管理员能够管理更多的服务器&#xff0c;而且在置备新的软件服务和维护现有软件服务时&#xff0c;具有…

visual studio 无法打开文件

55>已完成生成项目“306_EigenDecomposition_bin.vcxproj”的操作 - 失败。 56>LINK : fatal error LNK1104: 无法打开文件“..\..\Debug\glad.lib”文件夹权限问题

vulkan游戏引擎renderer_backend实现 - 详解

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

详细介绍:【使用】【经验】docker 清理未使用的镜像的命令

详细介绍:【使用】【经验】docker 清理未使用的镜像的命令pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consol…

关于网站制作报价微信小程序自助建站

作者&#xff1a;刘志勇&#xff0c;本文来自新浪微博视频平台资深架构师刘志勇在 LiveVideoStackCon 2018 讲师热身分享&#xff0c;并由 LiveVideoStack 整理而成。 本文从设计及服务可用性方面&#xff0c;详细解析了微博短视频高可用、高并发架构设计中的问题与解决方案。…

怎么建设局域网网站展示照片的网站

数环通让您可以通过不到几分钟的时间即可实现RSS订阅与Notion的对接与集成&#xff0c;从而高效实现工作流程自动化&#xff0c;降本增效&#xff01; 1.产品介绍 RSS订阅是数环通的内置应用&#xff0c;很多用户通过RSS订阅来收集自己在各大平台上看的内容&#xff0c;当RSS…

基于MPPT算法的光伏并网发电系统simulink建模与仿真

1.课题概述 基于MPPT算法的光伏并网发电系统simulink建模与仿真,包括PV光伏发电模块,并网电路,MPPT,PWM等模块。 2.系统仿真结果 3.核心程序与模型版本:MATLAB2022a 4.系统原理简介 光伏并网逆变器…