如何用 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。


需求说明

  • 项目依赖 element-plus@2.4.4
  • 官方在 2.5.0 修复了一个严重 bug(见 PR#15197)
  • 现有项目不方便直接升级 element-plus
  • 目标:只打补丁,修复 bug,且能持续跟随依赖升级

方案选型

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

  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 的改动,找到:

  • components/date-picker/src/date-picker-com/panel-date-pick.js(lib 目录)
  • components/date-picker/src/date-picker-com/panel-date-pick.mjs(es 目录)

分别做如下修改:

将:

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 是否生效

  • 直接在 node_modules/element-plus/es/components/date-picker/src/date-picker-com/panel-date-pick.mjslib/ 目录下,搜索你的改动(比如加个 console.log)。
  • 页面上触发 date-picker,控制台应有输出。
  • 如果没生效,优先怀疑缓存问题或实际用的不是被 patch 的文件。

常见问题与排查

  1. patch 文件没生效?

    • 检查 package.json 里的 pnpm.patchedDependencies 配置
    • patch 文件路径和 node_modules 结构必须完全一致
    • 清理所有缓存和 lock 文件,重新 install
  2. 只 patch 了 lib 或 es 目录?

    • 两个都要 patch,Vite 默认用 es 目录
  3. pnpm 版本太低?

    • 建议用 pnpm 7.x 或 8.x,老版本不支持 patchedDependencies
  4. 构建工具缓存?

    • 清理 .vitedist.cache 等目录
  5. 实际用的不是 element-plus?

    • 检查 import 路径,确认用的就是 node_modules 里的 element-plus

总结

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

遇到类似问题,记得:

  • patch lib 和 es 两套产物
  • 清理构建缓存
  • 检查 patch 是否真正生效

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


参考资料:

  • element-plus PR#15197
  • pnpm patch 官方文档
  • patch-package 官方文档

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

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

相关文章

Spring AI 入门:Java 开发者的生成式 AI 实践之路

一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…

优化电脑的磁盘和驱动器提高电脑性能和延长硬盘寿命?

磁盘优化 磁盘清理: 使用系统自带的磁盘清理工具(如Windows的“磁盘清理”)删除不必要的文件。清空回收站。删除临时文件和缓存。 磁盘碎片整理(针对机械硬盘): 定期进行磁盘碎片整理,以提高文…

EDA断供危机下的冷思考:中国芯片设计软件的破局之道优雅草卓伊凡

EDA断供危机下的冷思考:中国芯片设计软件的破局之道优雅草卓伊凡 一、EDA是什么?芯片行业的”隐形基石” 1.1 EDA技术解析 EDA(Electronic Design Automation,电子设计自动化)是用于设计和验证集成电路的软件工具链…

Jpackage

简介 jpackage - 用于打包自包含 Java 应用程序的工具,是 JDK 14 引入的一个工具。 该工具将 Java 应用程序和 Java 运行时映像作为输入,并生成包含所有必要依赖项的 Java 应用程序映像。它将能够生成特定于平台的格式的本机包,例如包括打包 …

CRM管理软件的数据可视化功能使用技巧:让数据驱动决策

在当今数据驱动的商业环境中,CRM管理系统的数据可视化功能已成为企业优化客户管理、提升销售效率的核心工具。据企销客研究显示,具备优秀可视化能力的CRM系统,用户决策效率可提升47%。本文将深入解析如何通过数据可视化功能最大化CRM管理软件…

智慧充电:新能源汽车智慧充电桩的发展前景受哪些因素影响?

全球能源结构转型与碳中和目标的推进,新能源汽车产业迎来爆发式增长,而智慧充电桩作为其核心基础设施,发展前景备受关注。智慧充电不仅关乎用户充电体验的优化,更是电网平衡、能源效率提升的关键环节。 然而,其发展并…

ABAP设计模式之---“简单设计原则(Simple Design)”

“Simple Design”(简单设计)是软件开发中的一个重要理念,倡导以最简单的方式实现软件功能,以确保代码清晰易懂、易维护,并在项目需求变化时能够快速适应。 其核心目标是避免复杂和过度设计,遵循“让事情保…

多模态大语言模型arxiv论文略读(105)

UnifiedMLLM: Enabling Unified Representation for Multi-modal Multi-tasks With Large Language Model ➡️ 论文标题:UnifiedMLLM: Enabling Unified Representation for Multi-modal Multi-tasks With Large Language Model ➡️ 论文作者:Zhaowei…

SQLServer中的存储过程与事务

一、存储过程的概念 1. 定义 存储过程(Stored Procedure)是一组预编译的 SQL 语句的集合,它们被存储在数据库中,可以通过指定存储过程的名称并执行来调用它们。存储过程可以接受输入参数、输出参数,并且可以返回执行…

使用UDP连接ssh

使用UDP连接ssh mosh简介两端安装moshWindows安装mosh 放行端口使用mosh登录Linuxdebug mosh简介 Mosh最大的特点是基于UDP方式传输,支持在服务端创建一个临时的Key供客户端一次性连接,退出后失效;也支持通过SSH的配置进行认证,但…

软件功能模块归属论证方法

文章目录 **一、核心设计原则****二、论证方法****三、常见决策模式****四、验证方法****五、反模式警示****总结** 在讨论软件功能点应该归属哪些模块时,并没有放之四海而皆准的固定方法,但可以通过系统化的论证和设计原则来做出合理决策。以下是常见的…

ServBay 1.13.0 更新,新增第三方反向代理/内网穿透

ServBay 作为一款简化本地开发环境搭建与管理的强大工具,致力于打造一个开箱即用、稳定可靠的本地开发平台,让用户专注于代码编写,提升开发效率。 ServBay 1.13.0 正式发布!本次更新聚焦于提升本地开发项目的外部可访问性、增强国…

如何利用乐维网管进行IP管理

IP管理是网络管理中的关键环节,对于保障网络的正常运行、提升资源利用效率以及保障网络安全等方面都具有不可忽视的重要性。乐维网管在IP管理方面具有多种实用功能,以下从IP规划与分配、IP状态监测、IP冲突处理、IP审计与报表生成四个方面,介…

Go语言学习-->go的跨平台编译

Go语言学习–>go的跨平台编译 默认我们go build的可执行文件都是当前操作系统可执行的文件,Go语言支持跨平台编译——在当前平台下编译其他平台的可执行文件。 eg:在windows界面的代码,编译完成后在linux上面运行 实现方式&#…

SpringBoot自动配置原理深度解析

一、引言 SpringBoot的"约定优于配置"理念极大地简化了Spring应用的开发流程,而其核心魔法就是自动配置(Auto-Configuration)。本文将深入剖析自动配置的实现原理,帮助开发者更好地理解和定制SpringBoot应用。 二、自动配置核心机制 1. Ena…

使用阿里云百炼embeddings+langchain+Milvus实现简单RAG

使用阿里云百炼embeddingslangchainMilvus实现简单RAG 注意测试时,替换其中的key、文档等 import os from langchain_community.embeddings import DashScopeEmbeddings from langchain_community.vectorstores import Milvus from langchain_text_splitters impor…

事件监听 ——CAD C#二次开发

一、AutoCAD .NET API 事件机制 1. 事件监听核心 - Database.ModifyObjects 事件 当数据库中的实体(如图形对象)发生修改时触发,包括: - 几何属性变更(移动、缩放、旋转)。 - 非几何属性变更&#xff08…

动量及在机器人控制中的应用

动量是物理学中的一个基本概念,在机器人学中也有重要应用。以下是详细解释: 1. 动量的基本定义 动量(Momentum)是描述物体运动状态的物理量,定义为: 线性动量:$ p mv $ $ m $ 为质量&#xf…

LeetCode 2434.使用机器人打印字典序最小的字符串:贪心(栈)——清晰题解

【LetMeFly】2434.使用机器人打印字典序最小的字符串:贪心(栈)——清晰题解 力扣题目链接:https://leetcode.cn/problems/using-a-robot-to-print-the-lexicographically-smallest-string/ 给你一个字符串 s 和一个机器人,机器人当前有一个…

影楼精修-AI衣服祛褶皱算法解析

注:为避免侵权,本文所用图像均为AIGC生成或无版权网站提供; 衣服祛褶皱功能,目前在像素蛋糕、美图云修、百度网盘AI修图、阿里云都有相关的功能支持,它的价值就是将不平整的衣服图像,变得整齐平整&#xf…