pnpm 改造

npm 和 Yarn 的不足

磁盘空间浪费

  • 问题:npm 和 Yarn 都会将包完整地复制到每个项目的 node_modules 中。
  • 后果:如果你有 10 个项目都依赖了同一个版本的 React,你的硬盘上就会有 10 份 React 的副本。对于开发者来说,这很快就会吞噬数十 GB 的硬盘空间。
    幽灵依赖问题
  • 问题:由于 npm/Yarn 采用扁平化结构,即使你没有在 package.json 中声明某个包,只要它是你某个依赖项的依赖,你依然可以在代码中 import 它。
  • 后果:这会导致代码不安全。如果某天你的直接依赖项删除了这个间接依赖,你的代码就会因为找不到包而突然崩溃,而你甚至不知道为什么。
    依赖项不一致/安装变慢
  • 问题:在大型 monorepo 项目中,npm 和 Yarn 处理成百上千个包时,解析算法和文件 IO 压力巨大。
  • 后果:即使有 lock 文件,在大团队协作或 CI/CD 环境下,安装速度依然可能成为开发流程的瓶颈。

为什么选择 pnpm?

  • 更快的安装速度:pnpm 使用硬链接和符号链接,避免重复下载相同的包

  • 节省磁盘空间:所有包都存储在全局存储中,项目之间共享

  • yarn

  • pnpm

  • 更严格的依赖管理:默认情况下,只能访问 package.json 中声明的依赖,避免幽灵依赖

  • 更好的 monorepo 支持:原生支持 workspace,性能更优

Pnpm -w vue


安装 pnpm

npm install -g pnpm

迁移步骤

运行项目

  • pnpm默认会把子依赖放在 .pnpm 下,项目中没有在 package.json 中安装的导入会报错 ,

    • @sentry/browser 是被 node_modules 中 @sentry/vue 导入的
  • @sentry/browser in ./node_modules/@sentry/vue/esm/index.js
  • @sentry/core in ./node_modules/@sentry/vue/esm/integration.js
  • @sentry/utils in ./node_modules/@sentry/vue/esm/tracing.js
  • @vant/popperjs in ./node_modules/vant/lib/popover/index.js
    • 需要配置vue.config.js,告诉 webpack:遇到 pnpm 的软链接,不要当成陌生路径,顺着链接走,按真实包来解析
      // vue.config.js
      module.exports = {
      configureWebpack: (config) => {
      return {
      resolve: { symlinks: true }
      }
      }
      }
      • pnpm 是 软链接 + 内容寻址存储:
        node_modules/
        vant -> .pnpm/vant@4.x/node_modules/vant
        @sentry/vue -> .pnpm/@sentry+vue@x/node_modules/@sentry/vue
  • 导入了没有在 package.json 安装的包,手动安装相关依赖

  • 未安装 vue-loader

  • Vue loader 版本安装不对

发布版本

cmdb 设置 pnpm

相关推荐
崔庆才丨静觅4 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby60614 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了5 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅5 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅5 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅5 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment5 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅6 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊6 小时前
jwt介绍
前端
爱敲代码的小鱼6 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax