纱线与npm:您需要知道的一切

编程入门 行业动态 更新时间:2024-10-11 15:13:25

纱线与npm:<a href=https://www.elefans.com/category/jswz/34/1715106.html style=您需要知道的一切"/>

纱线与npm:您需要知道的一切

本文由Adrian Sandu , Marcello La Rocca , Matt Burnett , Nuria Zuazo和Vildan Softic进行了同行评审。 感谢所有SitePoint的同行评审人员使SitePoint内容达到最佳状态!

2016.10.26:文章已更新,以解决评论中提出的问题。

Yarn是由Facebook,Google,Exponent和Tilde构建的新JavaScript软件包管理器。 从官方公告中可以看出,其目的是解决这些团队面对npm的一些问题,即:

  • 安装软件包的速度/一致性不够,并且
  • 存在安全问题,因为npm允许软件包在安装时运行代码。

但是,请不要惊慌! 这不是尝试完全替换npm。 Yarn只是一个新的CLI客户端,可从npm注册表中获取模块。 注册表本身没有任何变化-您仍然可以照常获取和发布程序包。

现在每个人都应该跳上纱线炒作吗? 您很有可能在npm中从未遇到过这些问题。 在本文中,我们将比较npm和Yarn,以便您可以确定最适合您的。

纱线与npm:功能差异

乍一看,Yarn和npm看起来很相似。 当我们在内部窥视时,我们意识到使纱线与众不同的原因。

yarn.lock文件

package.json ,npm和Yarn都可以跟踪项目的依赖关系的文件中,版本号并不总是准确的。 相反,您可以定义一系列版本。 这样,您可以选择软件包的特定主要版本和次要版本,但允许npm安装可能修复某些错误的最新补丁。

在理想的语义版本控制世界中,补丁发布不会包含任何重大更改。 不幸的是,这并不总是正确的。 npm所采用的策略可能导致两台机器具有相同的package.json文件,安装了不同版本的软件包,可能会引入错误。

为避免软件包版本不匹配,将精确安装的版本固定在锁定文件中。 每次添加模块时,Yarn都会创建(或更新) yarn.lock文件。 这样,您可以保证另一台机器安装了完全相同的软件包,同时仍在package.json定义了一系列允许的版本。

在npm中, npm shrinkwrap命令也会生成一个锁定文件,并且npm install在读取package.json之前先读取该文件,就像Yarn首先读取yarn.lock 。 这里的重要区别是,Yarn始终创建和更新yarn.lock ,而npm默认情况下不创建一个,而仅在存在时更新npm-shrinkwrap.json

  1. yarn.lock文档
  2. NPM收缩包装文档

并行安装

每当npm或Yarn需要安装软件包时,它都会执行一系列任务。 在npm中,这些任务是按包依次执行的,这意味着它将等待包完全安装后再继续执行下一个。 Yarn并行执行这些任务,从而提高了性能。

为了进行比较,我使用npm和Yarn安装了Express软件包,但没有使用wrapw / lock文件并使用了干净的缓存。 总共安装42个软件包。

  • npm:9秒
  • 纱线:1.37秒

我简直不敢相信自己的眼睛。 重复这些步骤会产生相似的结果。 然后,我安装了gulp软件包,产生了195个依赖项。

  • npm:11秒
  • 纱:7.81秒

似乎差异密切取决于要安装的软件包的数量。 无论哪种方式,Yarn始终都更快。

清洁输出

默认情况下,npm非常详细。 例如,当运行npm install <package>时,它将递归列出所有已安装的软件包。 另一方面,纱线一点也不冗长。 当可以通过其他命令获取详细信息时,它会列出带有适当表情符号的信息(除非您使用的是Windows)少得多。

纱线与npm:CLI差异

除了某些功能差异外,Yarn还具有不同的命令。 删除了一些npm命令,对其他命令进行了修改,并添加了一些有趣的命令。

全球纱线

与npm不同,在npm中,使用-g--global标志执行全局操作,而Yarn命令需要以global为前缀。 就像npm一样,不需要全局安装特定于项目的依赖项。

global前缀仅适用于yarn addyarn binyarn lsyarn remove 。 除了yarn add ,这些命令与其npm等效。

  1. 纱线全球文档

纱线安装

npm install命令将从package.json文件安装依赖项,并允许您添加新的软件包。 yarn install仅按该顺序安装yarn.lockpackage.json列出的依赖项。

  1. 纱线安装文档
  2. npm安装文档

纱线添加[–dev]

npm install <package>相似, yarn add <package>允许您添加和安装依赖项。 就像该命令的名称所暗示的那样,它添加了一个依赖项,这意味着它会自动将对包的引用保存在package.json文件中,就像npm的--save标志一样。 Yarn的--dev标志将软件包添加为开发人员依赖项,就像npm的--save-dev标志一样。

  1. 纱线添加文件
  2. npm安装文档

纱线许可证[ls |生成免责声明]

在撰写本文时,尚无等效的npm。 yarn licenses ls列出所有已安装软件包的许可证。 yarn licenses generate-disclaimer生成一个免责声明,其中包含所有包装的所有许可证的内容。 一些许可证规定您必须在项目中包括项目的许可证,这使其成为执行此操作的相当有用的工具。

  1. 纱线许可证文件

为什么纱

此命令将查看依赖关系图,并找出在项目中安装给定软件包的原因。 也许您明确地添加了它,也许它是所安装软件包的依赖项。 yarn why帮助您找出答案。

  1. 纱为什么要记录

纱线升级[包装]

该命令将软件包升级到符合package.json设置的版本规则的最新版本,并重新创建yarn.lock 。 这类似于npm update

有趣的是,在指定软件包时,它会将软件包更新为最新版本,并更新package.json定义的标签。 这意味着此命令可能会将软件包更新到新的主要版本。

  1. 纱线升级文档

纱线生成锁

yarn generate-lock-entry命令根据package.json设置的依赖yarn generate-lock-entry生成yarn.lock文件。 这类似于npm shrinkwrap 。 请谨慎使用该命令,因为在通过yarn addyarn upgrade添加和升级依赖项时,会自动生成并更新锁定文件。

  1. 纱线生成锁入口文档
  2. NPM收缩包装文档

稳定性和可靠性

纱线炒作列车会脱轨吗? 在发布给公众的第一天,它确实收到了很多问题报告 ,但是已解决问题的比率也令人震惊。 两者都表明社区正在努力寻找并消除错误。 从问题的数量和类型来看,Yarn对于大多数用户而言似乎很稳定,但可能不适合极端情况。

请注意,尽管包管理器可能对您的项目至关重要,但它只是一个包管理器。 如果出现问题,重新安装软件包应该不会很困难,也不会恢复为npm。

未来

也许您知道Node.js和io.js之间的历史。 回顾一下:io.js是Node.js的一个分支,它是由一些核心贡献者在对项目的治理有分歧之后创建的。 相反,io.js选择了开放式管理。 在不到一年的时间里,两个团队达成了协议,io.js被合并回Node.js,而前者则被终止。 无论是非是非,这都为Node.js引入了许多很棒的功能。

我看到npm和Yarn的模式相似。 尽管Yarn不是一个分支,但是它改善了npm的一些缺陷。 如果npm从中吸取教训并要求Facebook,Google和其他Yarn贡献者帮助改善npm,这不是很酷吗? 尽管现在说这种情况还为时过早,但我希望会发生。

无论哪种方式,Yarn的前景都是光明的。 社区似乎很兴奋,并且很好地接受了这个新的软件包管理器。 不幸的是,没有可用的路线图,所以我不确定Yarn为我们带来什么惊喜。

结论

与npm相比,Yarn得分更高的默认值。 我们免费获得一个锁文件,安装软件包的速度非常快,它们会自动存储在package.json 。 安装和使用Yarn的影响也很小。 您可以仅在一个项目上尝试它,然后查看它是否对您有用。 这使Yarn成为npm的理想替代品。

我绝对建议迟早在单个项目上尝试使用Yarn。 如果您对安装和使用新软件持谨慎态度,请花几个月的时间。 毕竟,npm经过了实战测试,在软件开发领域绝对值得。

如果您碰巧发现自己在等待npm完成安装软件包,那可能是阅读迁移指南的最佳时机;)

你怎么看? 您已经在使用Yarn吗? 您愿意尝试一下吗? 还是这只是在加剧本已分散的生态系统的碎片化? 在下面的评论中让我知道。

From: /

更多推荐

纱线与npm:您需要知道的一切

本文发布于:2024-02-06 08:34:47,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1747641.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:您需要   纱线   npm

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!