包管理工具npm和Yarn的区别,我们该如何选择?
好家伙,学习新工具
1.为什么我们需要包管理器?
关于npm我们已经知道了,这是我们项目的包管理器,
我们现在用的无比顺手的工具,都是在无数的竞争中杀出来的,他们淘汰了无数的产品
首先,倘若我们不使用npm,那么我们应该如何去新建一个前端项目?
纯手工,把我们项目需要的项目一个个下载到我们的项目里面
手动创建项目意味着您需要手动管理项目的依赖和文件结构,包括下载和引入任何所需的库或框架。
想想都可怕,再加上各种bug
我们新建一个项目可能需要?半个小时左右
于是我们的好帮手出现了,包管理器npm
我们把我们的配置清单给npm,随后,npm帮我们下载我们项目依赖的包
于是我们从30分钟优化到1分钟
npm真是太伟大了
2.NPM出现问题
但随后,NPM又出现了一些问题
2.1.安装太慢
新项目拿到手,安装依赖太慢
npm install
npm 2会安装每一个包所依赖的所有依赖项。如果我们有这么一个项目,它依赖项目A,项目A依赖项目B,项目B依赖项目C,那么依赖树将如下所示:
node_modules
- package-A
-- node_modules
--- package-B
----- node_modules
------ package-C
-------- some-really-really-really-long-file-name-in-package-c.js
这个结构可能会很长。这对于Windows来说却是个破坏性的东西,因为有很多程序无法处理超过260个字符的文件路径名。
npm 3采用了扁平依赖关系树来解决这个问题,所以我们的3个项目结构现在看起来如下所示:
node_modules
- package-A
- package-B
- package-C
-- some-file-name-in-package-c.js
这样,一个原来很长的文件路径名就从./node_modules/package-A/node_modules/package-B/node-modules/some-file-name-in-package-c.js
变成了/node_modules/some-file-name-in-package-c.js。
这种方法的缺点是,npm必须首先遍历所有的项目依赖关系,然后再决定如何生成扁平的node_modules目录结构。
npm必须为所有使用到的模块构建一个完整的依赖关系树,这是一个耗时的操作,是npm安装速度慢的一个很重要的原因。
2.2.无法保持一致性
想像一下去和小黄一起开发一个项目登陆页面,然后,你们在不同的时间安装了依赖包,
而碰巧,其中一个包更新了,14.2.1变成了14.2.2,或许是其中的一个组件框的样式改变了,
于是你会发现,你两的项目跑起来会有微妙的差别,当然了,也有可能是其他的各种各样严重的bug
总之,依赖包的版本不统一,是一个非常大的问题,可能会导致严重的问题
3.Yarn出现
于是针对这两个问题,
Yarn出现了,他很好地解决的npm存在的一些问题
yarn更快(为什么?)
1.并行安装:Yarn 采用并行安装的方式,可以同时下载多个依赖包,而 npm 是串行安装,只能一个一个地下载。这意味着当你使用 Yarn 时,依赖包的安装过程更加高效。
2.本地缓存:Yarn 有一个本地缓存目录,用于存储已经下载过的依赖包。当你需要安装同一个依赖包的不同版本时,Yarn 可以直接从本地缓存中获取,而无需重新下载。这可以节省大量的下载时间。
3.精确的依赖管理:Yarn 会生成一个锁文件 (yarn.lock),用于确保每个开发者在不同环境下都使用相同版本的依赖包。这意味着在安装依赖包时,Yarn 可以更加准确地确定需要使用的版本,减少了版本冲突和不一致性问题。
在后来,
有了yarn的压力之后,npm做了一些类似的改进(对手起来了,再不与时俱进要就要被淘汰了)
1. 默认新增了类似yarn.lock的 package-lock.json,同样用于处理依赖包版本一致性的问题
2. git 依赖支持优化:这个特性在需要安装大量内部项目(,或需要使用某些依赖的未发布版本时很有用。
3.npm是有本地缓存的,它保存了已经下载的每个版本的压缩包。本地缓存的内容可以通过-npm cache ls命令进行查看。
本地缓存的设计有助于减少安装时间。
那么最终该如何选择呢?
1. 性能需求:如果你对构建速度和依赖包下载速度有较高的需求,可以使用Yarn。Yarn在处理大型项目和并发操作时通常更高效。
2. 生态系统和兼容性:Npm是JavaScript生态系统的默认选择,很多项目都使用Npm作为包管理工具,并且它与其他工具和服务的兼容性较好。
如果你的项目依赖于特定的Npm插件或服务,或者与其他使用Npm的项目进行交互,那么使用Npm可能更方便。
3. 社区支持和文档:Npm和Yarn都有庞大的社区和文档资源,但是Npm在这方面可能更加成熟和全面。
如果你更倾向于使用广泛支持的工具,并且更容易找到相关的教程、示例和问题解答,那么选择Npm可能是一个不错的选择。
4. 团队合作:如果你在一个团队中工作,建议与团队成员协商并讨论选择。考虑到团队中其他开发者的熟悉程度和偏好,可以决定是否使用Npm还是Yarn。
根据你的性能需求、生态系统要求、社区支持和团队合作等因素来衡量,选择适合你项目的工具。
无论是Npm还是Yarn,它们都是广泛使用的可靠工具,并且都能满足大部分项目的需求。
最后,yarn的安装方式
(用你的平台安装我,这何尝不是一种NTR)
包管理工具npm和Yarn的区别,我们该如何选择?的更多相关文章
- 主流包管理工具npm、yarn、cnpm、pnpm之间的区别与联系——原理篇
接触 node 之后,一直使用npm包管理工具, cnpm 一开始会用一些,但是并没有觉得比 npm 快得多,使用 cnpm 的时候还经常安装不成功,只能再用 npm 安装一遍,渐渐的就弃用了 cnp ...
- 更换包管理工具npm为yarn
官网:https://yarnpkg.com/zh-Hans/ 主要考虑: 1. npm管理安装模块依赖的版本不太方便,容易在删除node_modules重新install或在其他机器上新安装时, 安 ...
- JavaScript 包管理工具npm 和yarn 对比
- NodeJS包管理工具——npm入门
如今每个语言体系中都有一个包管理工具,PHP的Composer,Ruby的gem,Python的pip,Java的Maven……当然还有Node.js的npm.有的人会奇怪为何要引入又一个新东西来让我 ...
- 【前端】NodeJs包管理工具NPM
NPM是随同NodeJS一起安装的包管理工具,能解决NodeJS部署上的很多问题. 测试是否安装成功,出现版本提示表示安装成功. npm -v NPM常用命令 官方文档:https://www.npm ...
- node.js开发 npm包管理工具 npm 和 cnpm区别
npm 允许用户从NPM服务器下载别人编写的第三方包到本地使用. 允许用户从NPM服务器下载并安装别人编写的命令行程序到本地使用. 允许用户将自己编写的包或命令行程序上传到NPM服务器供别人使用 np ...
- nodejs包管理工具npm
用Node.js安装模块 在某个项目中单独安装的时候,npm会下载所有的文件到你项目中的一个叫做node_modules的文件夹内 全局模块会被安装到{prefix}/lib/node_modules ...
- Node包管理工具
Node包管理工具 只是简单的介绍一些工具的使用,有利于开发过程.除了介绍Node包管理工具,还介绍了前端打包工具,前端模块管理工具 Node包管理工具: --npm --cnpm ...
- 包管理工具(npm、yarn)
npm包管理工具 1. npm的包安装分为本地安装(local).全局安装(global)两种,从敲的命令行来看,差别只是有没有-g而已. 2. 这两种安装方式的区别: 本地安装(安装在命令行运行所在 ...
- Node.js之包与npm包管理工具
Node.js之包与npm包管理工具 1.Node.js中的包 1.1在一个包中包含如下内容: package.json:对包进行描述 在bin子目录中存放二进制文件 在lib子目录中存放JavaSc ...
随机推荐
- Python全栈开发工程师 day57 jQuery
二.jQuery样式操作标签样式操作<!DOCTYPE html><html lang="en"><head> <meta charset ...
- Linux云计算运维工程师day28shell编程基础
一. 1.全局变量.环境变量 Export OLDOBY="I am a oldboy." Echo OLDOBY OLDOBY="I am a oldboy.&quo ...
- Centos 安装 python3.x 为默认
CentOS 7 中默认安装了 Python,但是版本是2.x的,由于2020年python2.x将停止更新,因此需要将版本升级至3.x.但由于python2.x是系统集成的,很多命令都是要基于pyt ...
- Qt第三方库QtAV--- ubuntu编译与运行
Qt第三方库QtAV--- ubuntu编译与运行 今天又要接触这个,把一些错误或者不足的地方重新补充下!!!由于前面一段时间,项目中需要借助QtAV接口进行视频播放,特此记录下整个配置过程.整个代码 ...
- Spring源码:Bean的生命周期(二)
前言 让我们继续讲解Spring的Bean实例化过程.在上一节中,我们已经讲解了Spring是如何将Bean定义加入到IoC容器中,并使用合并的Bean定义来包装原始的Bean定义.接下来,我们将继续 ...
- MySQL高频面试题
什么是MySQL MySQL是一个关系型数据库,它采用表的形式来存储数据.你可以理解成是Excel表格,既然是表的形式存储数据,就有表结构(行和列).行代表每一行数据,列代表该行中的每个值.列上的值是 ...
- ai问答:使用 Vue3 组合式API 和 TS 封装 websocket 断线重连
这是一个使用 Vue3 组合式 API 和 TS 封装 websocket 的例子 这个组件在 setup 中: 创建了一个 WebSocket 连接 定义了 sendMessage 方法发送消息 监 ...
- Java web文件服务器的简单实现
先分享一个好用的聚合搜索引擎,https://www.tomfind.com/ ,支持谷歌.百度.搜狗.bing.360一键切换,支持网页.音乐.购物.视频搜索.支持抖音.快手.哔哩哔哩.微信.头条. ...
- Golang每日一库之regex
本文地址: https://www.cnblogs.com/zichliang/p/17387436.html Golang日库合集:https://www.cnblogs.com/zichliang ...
- Nginx常用基础模块
Nginx常用基础模块 目录 Nginx常用基础模块 目录索引模块 配置方式 nginx的状态模块 配置方式 nginx访问控制模块 配置方式 nginx的访问限制模块 请求限制重定向 Nginx连接 ...