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

相关推荐
cd_949217219 分钟前
2026年朝阳永续AI小二专业研投能力解析
前端·人工智能·easyui
FlyWIHTSKY10 分钟前
`nth-child()`的 基础用法
前端·html
Ww.xh21 分钟前
Figma设计稿转React代码:ClaudeCode+MCP实战教程
前端·react.js·figma
不老刘30 分钟前
破局 EMR 痛点:如何化解“护理记录跨页”与“A4物理打印”的架构冲突
前端·架构
m0_7381207235 分钟前
后渗透维权提权基础——CTF模拟红队进行权限维持(一)
服务器·前端·python·安全·web安全·php
朝阳3936 分钟前
react【实战】自定义下拉框、单选、多选、输入框
前端·javascript·react.js
涵涵(互关)40 分钟前
GoView各项目文件中的相关语法3
前端·vue.js·typescript
李白的天不白40 分钟前
vs code -- uniapp gets
前端
lifewange1 小时前
CNode API v1 完整接口文档(JSON 规范整理)
java·前端·json
QQ1__8115175159 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot