pnpm add 和 pnpm install 的区别?

文章目录

      • [1. pnpm add](#1. pnpm add)
      • [2. pnpm install](#2. pnpm install)
      • [3. 总结](#3. 总结)
      • 应用场景
      • 示例

在使用 pnpm 管理项目依赖时, pnpm addpnpm install 是两个常用的命令,但它们的功能和使用场景有所不同。以下是详细的解释:


1. pnpm add

功能 :用于向项目的 package.json 文件中添加新的依赖项,并安装这些依赖项。

特点

  • 添加依赖 :会将指定的包添加到 dependenciesdevDependenciesoptionalDependencies 中。
  • 自动安装 :不仅会更新 package.json,还会立即安装新添加的依赖项。
  • 灵活性 :可以通过参数指定依赖项的类型(如 --save-dev 添加到 devDependencies)。

常用选项

  • --save-dev-D:将包添加到 devDependencies
  • --save-peer-P:将包添加到 peerDependencies
  • --save-optional-O:将包添加到 optionalDependencies
  • --save-exact-E:保存精确版本号。

示例

bash 复制代码
# 添加一个新的生产依赖项
pnpm add react react-dom

# 添加一个新的开发依赖项
pnpm add --save-dev @types/react @types/react-dom

# 添加并保存精确版本号
pnpm add --save-exact lodash

2. pnpm install

功能 :根据 package.json 文件中的依赖项列表安装所有依赖项。

特点

  • 安装现有依赖 :不会修改 package.json,只是根据已有的依赖项列表安装所需的包。
  • 适用于多种场景 :常用于克隆仓库后首次安装依赖,或者在更改了 package.json 后重新安装所有依赖项。
  • 处理锁文件 :会根据 pnpm-lock.yaml 文件确保安装的依赖项版本一致。

示例

bash 复制代码
# 安装所有依赖项
pnpm install

# 安装特定版本的依赖项(如果需要)
pnpm install react@18.3.1 react-dom@18.3.1

3. 总结

  • pnpm add :用于添加新的依赖项并安装它们,同时更新 package.json
  • pnpm install :仅用于安装 package.json 中已列出的依赖项,不会修改 package.json

应用场景

  • 开发过程中添加新依赖 :使用 pnpm add 来添加新的库或工具,并确保它们被记录在 package.json 中。
  • 初始设置或更新依赖 :使用 pnpm install 来安装所有现有的依赖项,特别是在克隆仓库或更新 package.json 后。

示例

假设你想要添加一个新的开发依赖项 typescript,你可以使用以下命令:

bash 复制代码
pnpm add --save-dev typescript

这将更新 package.json 并安装该插件。

如果你只是想确保所有现有依赖项都已正确安装,可以运行:

bash 复制代码
pnpm install

这将根据 package.jsonpnpm-lock.yaml 安装所有必要的依赖项。

相关推荐
小笔学长1 天前
Webpack 配置优化:提高打包速度与质量
前端·项目实战·前端开发·webpack优化·打包性能优化
优爱蛋白1 天前
SCF His Tag 重组蛋白:c-Kit受体信号研究与干细胞培养应用的关键试剂
前端·人工智能·健康医疗
C_心欲无痕1 天前
react - Suspense异步加载组件
前端·react.js·前端框架
JosieBook1 天前
【Vue】05 Vue技术——Vue 数据绑定的两种方式:单向绑定、双向绑定
前端·javascript·vue.js
想学后端的前端工程师1 天前
【浏览器工作原理与性能优化指南:深入理解Web性能】
前端·性能优化
程序员爱钓鱼1 天前
Node.js 编程实战:错误处理与安全防护
前端·后端·node.js
Geoffwo1 天前
Electron 打包后 exe 对应的 asar 解压 / 打包完整流程
前端·javascript·electron
柒@宝儿姐1 天前
vue3中使用element-plus的el-scrollbar实现自动滚动(横向/纵横滚动)
前端·javascript·vue.js
程序员爱钓鱼1 天前
Node.js 编程实战:模板引擎与静态资源
前端·后端·node.js
Geoffwo1 天前
Electron打包的软件如何使用浏览器插件
前端·javascript·electron