📦 npm、yarn、pnpm、bun 是什么

🎯 什么是包管理器?

在 JavaScript 和 Node.js 生态中,一个项目往往依赖很多第三方库,比如 Vue、React、Lodash 等。**包管理器(Package Manager)**的作用,就是:

  • 安装/卸载这些依赖库;

  • 管理依赖的版本;

  • 构建依赖树;

  • 提供运行脚本(如 npm run dev)等功能。

最早是 npm,后来有了性能更好的 yarn,又有了极致节省空间的 pnpm,最近还杀出了一个全能选手 —— bun。


📌 1. npm:最原始、最广泛的包管理器

  • 全称:Node Package Manager

  • 开发者:Node.js 官方团队

  • 地位:最基础、最广泛使用的工具(Node.js 安装时自带)

  • 命令前缀:npm

✅ 特点

  • 社区最广泛支持;

  • 包管理逻辑清晰,学习资料丰富;

  • 缺点是早期安装速度较慢、存在重复安装、依赖树冗余等问题;

  • 从 npm v7 开始改进了很多(比如支持 workspaces)。

🚀 常用命令示例

 1npm install          
 2npm install vue      
 3npm uninstall vue    
 4npm run serve        

📌 2. yarn:Facebook 出品,解决 npm 的痛点

  • 开发者:Facebook

  • 诞生原因:为了解决 npm 安装速度慢、锁文件混乱、网络不稳定等问题

  • 命令前缀:yarn

✅ 特点

  • 更快的安装速度(缓存机制);

  • 使用 yarn.lock 文件,锁定版本更清晰;

  • 原生支持 monorepo(多包项目);

  • 更优雅的输出格式,更友好的用户体验;

  • v2 开始重构为 Plug’n’Play 模式(默认禁用 node_modules)。

🚀 常用命令示例

 1yarn                # 安装所有依赖
 2yarn add axios      # 添加依赖
 3yarn remove axios   # 删除依赖
 4yarn dev            # 运行脚本

📌 3. pnpm:磁盘空间终结者,速度与规范兼得

  • 全称:Performant npm

  • 开发者:Zoltan Kochan 等开源作者

  • 命令前缀:pnpm

✅ 特点

  • 使用符号链接和内容寻址(类似 git)机制,实现依赖复用;

  • 同一包只在硬盘上存一份,极大节省 node_modules 空间;

  • 安装速度极快;

  • 结构更规范、更严格,不容易出现“依赖地狱”;

  • 完全兼容 npm 的语法。

🚀 常用命令示例

 1pnpm install           # 安装依赖
 2pnpm add vue           # 安装 vue
 3pnpm remove vue        # 删除 vue
 4pnpm run dev           # 运行脚本

🎁 小彩蛋:pnpm 能用来一键初始化 Vite 项目

 1pnpm create vite

📌 4. bun:下一个全能型选手(包管理 + JS 运行时 + 构建工具)

  • 开发者:Jarred Sumner

  • 诞生时间:2022 年

  • 核心目标替代 Node + npm/yarn + webpack 等工具链

  • 命令前缀:bun

✅ 特点

  • 内置 包管理器、JS 执行器、构建器 三合一;

  • 使用 Zig 编写,性能极高;

  • 安装依赖比 npm 快十几倍;

  • 启动脚本更快、内存占用更少;

  • 仍在快速更新,生态在逐步扩展中。

🚀 常用命令示例

 1bun install          # 安装依赖
 2bun add vue          # 安装 vue
 3bun remove vue       # 删除 vue
 4bun run dev          # 运行脚本
 5bun index.ts         # 直接执行 TypeScript 文件

⚠️ 注意:bun 虽然很强,但目前生态还不如 npm/yarn/pnpm 完善,适合技术探索者或追求极致性能的场景。


📊 对比总结表格(最重要)

功能 / 特性npmyarnpnpmbun
出现时间最早后于 npm后于 yarn最晚
安装速度一般(新版改善)较快(有缓存)极快(复用依赖)最快(Zig 编写)
节省磁盘空间✅ 是✅ 是
锁文件package-lock.jsonyarn.lockpnpm-lock.yamlbun.lockb
原生 monorepo 支持有(v7+)✅ 是✅ 是正在完善
生态稳定性✅ 最成熟✅ 成熟✅ 稳定🚧 新但潜力大
是否默认带 node_modules✅ 是✅ 是✅ 是(使用硬链接)❌(使用虚拟 FS)
推荐人群初学者 / 通用跨团队协作追求性能与规范高性能探索者

✅ 开发建议(如何选择?)

你是谁推荐选择
刚接触前端的新手✅ npm(默认自带,文档最多)
想要更快构建、更稳定依赖✅ yarn 或 pnpm
大型项目、多包管理(monorepo)✅ pnpm
技术极客、极限性能控✅ bun

✍️ 写在最后

JavaScript 生态非常活跃,每一个包管理器都有其适合的使用场景。现在你已经了解了它们之间的区别,可以根据自己的需求合理选择工具,为开发提速、为项目减负。

个人笔记记录 2021 ~ 2025