nodeJS下npm和yarn的关系和区别详解

一、命令对应关系

1. 初始化项目

操作 npm 命令 Yarn 命令
初始化项目 npm init yarn init
跳过提问快速初始化 npm init -y yarn init -y

2. 安装依赖

操作 npm 命令 Yarn 命令
安装项目所有依赖 npm install yarn install
添加依赖 npm install <package-name> yarn add <package-name>
添加开发依赖 npm install <package-name> --save-dev yarn add <package-name> --dev
添加全局依赖 npm install -g <package-name> yarn global add <package-name>
安装特定版本的依赖 npm install <package-name>@<version> yarn add <package-name>@<version>

3. 删除依赖

操作 npm 命令 Yarn 命令
删除依赖 npm uninstall <package-name> yarn remove <package-name>
删除全局依赖 npm uninstall -g <package-name> yarn global remove <package-name>

4. 更新依赖

操作 npm 命令 Yarn 命令
更新依赖 npm update <package-name> yarn upgrade <package-name>
更新所有依赖到最新版本 npm update yarn upgrade

5. 清理缓存

操作 npm 命令 Yarn 命令
清理缓存 npm cache clean --force yarn cache clean

6. 查看信息

操作 npm 命令 Yarn 命令
查看包信息 npm info <package-name> yarn info <package-name>
查看依赖树 npm list yarn list

7. 运行脚本

操作 npm 命令 Yarn 命令
运行脚本 npm run <script-name> yarn <script-name>
查看所有脚本 npm run yarn run

二、两者的主要区别

1. 性能对比

  • Yarn:并行化安装依赖,比 npm 更快,尤其是首次安装时。
  • npm:较早版本的 npm 安装较慢,但自 npm 5+ 起,性能有了显著提升。

2. 锁定文件

  • Yarn :使用 yarn.lock 文件,确保团队环境中依赖版本的一致性。
  • npm :使用 package-lock.json 文件,功能类似,但结构稍有不同。

3. 缓存机制

  • Yarn:默认会将所有下载的包缓存到本地,再次安装时直接读取缓存,无需重新下载。
  • npm:有缓存机制,但需要手动配置才能达到类似 Yarn 的效果。

4. 工作空间(Monorepo)支持

  • Yarn :原生支持工作空间(workspaces),适合管理 Monorepo 项目。
  • npm:从 npm 7 开始支持工作空间,但功能不如 Yarn 强大。

5. 命令简洁性

  • Yarn 的命令更简洁。例如:
    • 添加依赖:yarn add vs. npm install
    • 删除依赖:yarn remove vs. npm uninstall

6. 全局依赖管理

  • Yarn :全局依赖通过 yarn global add 管理,独立于系统环境。
  • npm :全局依赖通过 npm install -g 管理,依赖系统环境,容易出现权限问题。

三、选择 Yarn 还是 npm?

场景 推荐工具
项目需要更快的安装速度 Yarn
项目需要使用 Monorepo 管理 Yarn
项目需要更广泛的社区支持 npm
追求更现代的依赖管理工具 Yarn 或 npm 7+

总结:

  • Yarn:适合需要高性能和复杂依赖管理的项目。
  • yarn:随着版本升级,已大大缩小与 Yarn 的差距,适合大多数场景。

你可以根据项目需求选择 Yarn 或 npm。如果你的团队使用 Yarn,可以统一使用它;如果没有特殊需求,npm 已经是一个可靠的选择。

相关推荐
OEC小胖胖1 小时前
告别 undefined is not a function:TypeScript 前端开发优势与实践指南
前端·javascript·typescript·web
行云&流水1 小时前
Vue3 Lifecycle Hooks
前端·javascript·vue.js
老虎06272 小时前
JavaWeb(苍穹外卖)--学习笔记04(前端:HTML,CSS,JavaScript)
前端·javascript·css·笔记·学习·html
三水气象台2 小时前
用户中心Vue3网页开发(1.0版)
javascript·css·vue.js·typescript·前端框架·html·anti-design-vue
烛阴2 小时前
Babel 完全上手指南:从零开始解锁现代 JavaScript 开发的超能力!
前端·javascript
CN-Dust3 小时前
[FMZ][JS]第一个回测程序--让时间轴跑起来
javascript
全宝4 小时前
🎨前端实现文字渐变的三种方式
前端·javascript·css
yanlele4 小时前
前端面试第 75 期 - 2025.07.06 更新前端面试问题总结(12道题)
前端·javascript·面试
妮妮喔妮4 小时前
【无标题】
开发语言·前端·javascript
fie88894 小时前
浅谈几种js设计模式
开发语言·javascript·设计模式