npm yarn pnpm 包管理器区别

npm、yarn和pnpm都是JavaScript的包管理工具,它们的主要区别如下:

  1. 性能:在处理依赖安装时,yarn和pnpm相对于npm会更快,因为它们支持并行安装。但是在其他方面,如缓存等,各自的性能表现可能有所不同。

  2. 安全性:yarn和pnpm相对于npm有更好的安全性,因为它们提供了更严格的依赖版本锁定机制。例如,yarn.lock文件中列出的依赖版本不会被修改。

  3. 可靠性:由于依赖的版本锁定机制,yarn和pnpm可以更可靠地重建相同的环境。

  4. 兼容性:npm是Node.js的默认包管理器,因此它们是高度兼容的。yarn和pnpm也是基于npm的,并且可以与npm存储库和包配合使用,但是由于某些操作行为的差异,可能会导致一些兼容性问题

1.npm

使用npm  i 下载的node_modules文件  里面的包之间的关系是树关系,比如 node_modules有A,B两个包 两个包又同时依赖了C  那么C包就会被安装两次在A,B文件中  这一来就造成了磁盘上的资源浪费  而且不好管理每个包的版本 会出现幽灵依赖(package.json 中声明的依赖,但在项目中依然可以意外的被正确引用。)
2.yarn

yarn的出现解决了  npm  多次下载同一个包的问题 他会把的文件树扁平化 不管包与包之前有多深  都会被提出来 然后多个文件依赖一个包的话就会指向一个地方   yarn 使用单独的缓存目录,并把每个包的所有版本都下载到本地,每个项目都使用相同的 node_modules 目录。

3pnpm 

PNPM 也使用单独的缓存目录,但它只下载每个包的最新版本,并在项目中使用符号链接来引用缓存中的依赖,从而实现更好的磁盘占用和更快的安装速度。

你可能感兴趣的:(npm,前端,node.js,yarn)