近日,pnpm v9.0.0 正式发布!带来了一系列重大更新和改进,让你的开发体验更加顺畅。现在可以通过 npm install -g pnpm
来升级 pnpm 到最新版本,接下来让我们一起看一下 pnpm v9 有哪些亮眼的新功能吧。
🔥 Node.js 支持
pnpm v9.0.0 现已停止对 Node.js v16 提供支持,但不用担心,现在将 pnpm 与 Node.js 一起捆绑发布。
这意味着,无论你安装了哪个版本的 Node.js,pnpm 都会使用必要的 Node.js 运行时。你只需通过独立脚本或者安装 @pnpm/exe
包来安装 pnpm,就能实现这一功能。
🔧 Corepack 功能增强
现在 pnpm 会检查 package.json
文件中的 packageManager
字段。
如果该字段存在,并且指定了不同的包管理器或者不同版本的 pnpm,pnpm 将停止执行。这确保你始终使用项目所需的正确的包管理器和版本。
🔔 配置更新
默认禁用 link-workspace-packages
,这意味着默认情况下,只有在使用工作区协议指定依赖项时,才会从工作区包中链接依赖项。
默认启用 dedupe-injected-deps
。
默认启用 hoist-workspace-packages
和 enable-pre-post-scripts
。
在 macOS 上使用与 Linux 相同的目录 ~/.local/state/pnpm
存储状态文件。
🔒 锁定文件更新
采用了 Lockfile v9,新的格式更易读,并且更能抵抗 Git 冲突。不再支持 lockfile v5,使用 pnpm v8 将 lockfile v5 转换为 lockfile v6。
🔍 依赖解析更新
正确解析具有自己的对等依赖项的对等依赖项,可从依赖图中的任何包解析可选的对等依赖项。
pnpm licenses list
现在打印同一软件包的所有版本的许可信息,以防不同版本使用不同的许可证。
🎉 新增命令
pnpm completion [shell]
,用于将完成代码打印到控制台。
已移除修改用户 shell dotfiles
的旧命令。
🔧 其他改进
现在可以仅从 Git 子目录安装依赖项,例如:
shell
pnpm add github:user/repo#path:packages/foo
将从 packages/foo
子目录添加依赖项。此新参数可以与其他支持的参数组合使用。
node-gyp
已更新到版本 10。- 新增 PowerShell 完成支持。
- 运行脚本时,支持在
.npmrc
文件中使用node-options
选项。 - 新增支持注册表范围的 SSL 配置(cert、key 和 ca)。
- 新增 ignoredOptionalDependencies 字段,用于跳过指定的可选依赖项。
.pnpmfile.cjs
的校验和保存在锁定文件中。- 新增
pnpm dlx
的缓存功能。
🛠 修复内容包括
- 安装
--lockfile-only
时不下载软件包tarballs
- 对等依赖规则只影响报告而不影响锁定文件中的数据
- 链接覆盖可以使用绝对路径
pnpm dlx
不应从当前工作目录读取设置。
🌟 升级到 pnpm v9.0.0,享受更好的开发体验吧!