使用 pnpm patch 修改第三方依赖

背景

最近发现公司项目中使用 @fortawesome/vue-fontawesome 第三方依赖后,会导致 Vite 工具打包构建的产物中带有 require 语法

本地开发环境中,启用 node server 服务,Node 环境中有 require 方法,所以本地正常。但是线上部署环境中,是纯浏览器环境,没有 require 方法,导致出现 require is not undefined 的错误,如下图所示

问题原因

经过我的仔细排查,发现在 @fortawesome/vue-fontawesome 的源码中,有这样一段代码

js 复制代码
// node_modules/@fortawesome/vue-fontawesome/index.js
// node_modules/@fortawesome/vue-fontawesome/index.es.js

var svgCorePackageJson = require('@fortawesome/fontawesome-svg-core/package.json');
var SVG_CORE_VERSION = svgCorePackageJson.version;

Vite 工具会将这段代码原封不动打包到构建产物中,导致浏览器环境出现问题

解决思路

因为项目本身使用 pnpm 包管理器,所以选择使用 pnpm patch 修改第三方包,删除导致问题的代码,彻底从源头上解决问题

步骤一

清理旧的 node_module,重新安装所有依赖

shell 复制代码
rm -rf node_modules && pnpm install

步骤二

运行 pnpm patch 命令,它会创建一个临时的、可供你修改的包副本

shell 复制代码
pnpm patch @fortawesome/vue-fontawesome

非常重要: 命令执行后,你会看到类似这样的输出:

shell 复制代码
Changes can be made in a temporary directory. When you're done, run 'pnpm patch-commit /private/var/folders/.../temp-dir-for-patching-...'
Patching @fortawesome/vue-fontawesome@x.y.z
/private/var/folders/.../temp-dir-for-patching-...  <-- **请复制并记住这个临时目录的完整路径!**

请务必复制并保存这个临时目录的完整路径!

步骤三

进入临时目录并修改文件

bash 复制代码
cd /private/var/folders/.../temp-dir-for-patching-... # 将此路径替换为你实际复制的路径

打开第三方依赖的构建产物,修改代码。

js 复制代码
// var svgCorePackageJson = require('@fortawesome/fontawesome-svg-core/package.json');
// var SVG_CORE_VERSION = svgCorePackageJson.version;
var SVG_CORE_VERSION = '7.0.0'; // 或者其他你认为合适的版本号

注意所有有问题的构建产物都要修改

步骤四

提交补丁并生成 .patch 文件,回到项目根目录,执行下面的命令

csharp 复制代码
pnpm patch-commit /private/var/folders/.../temp-dir-for-patching-... # 替换为你的临时目录路径

这一步会在项目的根目录下创建 patches 文件夹和 pnpm-workspace.yaml

pnpm-workspace.yaml 内容如下

步骤五

删除 node_modulespnpm-lock.yaml,然后运行 pnpm install

shell 复制代码
rm -rf node_modules
rm -f pnpm-lock.yaml
pnpm install

步骤六

shell 复制代码
pnpm run build

部署到生产环境,查看是否修复

相关推荐
陈随易8 分钟前
bun将会支持Bun.image,你怎么看?
前端·后端·程序员
jingqingdai325 分钟前
别用正则格式化 HTML!我用 DOM 遍历实现零风险本地格式化,老项目重构效率直接拉满
前端·重构·html
木斯佳28 分钟前
前端八股文面经大全:腾讯前端实习二、三OC面(2026-04-27)·面经深度解析
前端·状态模式
Python私教41 分钟前
如意Agent日志系统重构:从 print() 大海捞针到结构化可观测性栈
java·前端·重构
We་ct1 小时前
LeetCode 97. 交错字符串:动态规划详解
前端·算法·leetcode·typescript·动态规划
Chengbei111 小时前
轻量化 Web 安全日志分析神器 星川智盾日志威胁检测、地理溯源、MITRE ATT&CK 映射,支持 Windows/macOS/Linux
前端·人工智能·安全·web安全·macos·系统安全·安全架构
风流 少年1 小时前
Python Web框架:FastAPI
前端·python·fastapi
GISer_Jing1 小时前
AI时代面试新常态——从“会用工具”到“深挖原理”的跨越
前端·人工智能·ai编程
IT_陈寒1 小时前
React的useEffect把我坑惨了,这些闭包陷阱真要命
前端·人工智能·后端