利用yarn代替npm管理前端项目模块依赖的方法详解


Posted in Javascript onSeptember 04, 2017

本文主要给大家介绍了关于yarn代替npm管理前端项目模块依赖的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

什么是 yarn?

简单来说,yarn 是一个与 npm 功能相同的工具,用于前端项目的依赖管理。在使用 npm 的项目中,使用 npm 命令的地方都可以使用 yran 来代替。

为什么要使用 yarn 替代 npm 呢?yarn 相对 npm 来说,主要的特点有:

  • 离线、并行安装:依赖并行安装,缓存已下载过的依赖并优先使用,各种优化使得安装依赖速度显著提升
  • 确定性:默认生成 yarn.lock 文件,可以保证各开发人员开发安装依赖的目录具有一致性
  • more…

好吧,其实 npm 也在不断的优化改进中。但 yarn 确实有很多亮点,至少当前是非常值得你去使用的。

yarn 使用快速上手

安装

虽然安装 yarn 可以不依赖 npm,但这里还是建议你使用 npm 来安装吧,快速而简洁:

npm i -g yarn

在项目中使用

首次初始化项目时执行,在每次项目启动/构建之前,也都应执行一次,以保证本地依赖得到及时更新。

该命令会检查 package.json 和 yarn.lock 文件中的依赖,当有其内容更新,会进行依赖更新安装。

yarn <install>

依赖更新。当你希望更新依赖模块到其最新版本时执行该命令。

yarn upgrade

yarn 常用命令

开始新项目

yarn init

添加依赖包

yarn add [package]
yarn add [package]@[version]
yarn add [package]@[tag]

升级依赖包

yarn upgrade [package]
yarn upgrade [package]@[version]
yarn upgrade [package]@[tag]

移除依赖包

yarn remove [package]

安装项目的全部依赖

yarn

或者

yarn install

yarn 使用实践建议

我们选择 yarn 的主要原因是依赖安装速度快,默认生成的 yarn.lock 会保证所有成员的模块依赖目录能够很好的保持一致。

yarn install 和 yarn upgrade 的执行逻辑,可以让你可以很清晰的管理本地依赖的版本更新时机,又能很好的让所有开发人员的本地依赖保持一致性。

使用 npm install 则有些乱,当你不想写死版本号依赖时,它总会安装依赖包最新可用的版本,但这在有时候并不是你想要的。

在 yarn 之前,我们使用的是 npm+淘宝仓库方案,也会使用 cnpm。在国内,cnpm 的依赖安装速度比 yarn 还要快,但 cnpm 在 windows 下通过创建链接引用的方式管理包依赖,可能会带来一些问题。

现在我们会默认使用淘宝仓库,使用 npm 管理全局依赖,使用 yarn 管理具体项目内的依赖。

在一个新的项目中使用 yarn,我们会这么来做:

  • 写好 package.json,写入初始的第三方依赖
  • 执行 yarn 命令,初始化安装项目依赖,生成 yarn.lock 文件
  • 后续通过执行 yarn add xxx 添加更多需要的依赖(也可直接在 package.json 文件中写入)
  • 当确定需要更新依赖模块到其最新版本时,执行 yarn upgrade 命令
  • 配置项目启动命令执行前,先执行 yarn 命令,以保证当 yarn.lock 被更新时,本地依赖也及时得到更新。例如,在 package.json 的 script 部分中配置 start 命令: "start": "yarn && yarn run build:dev"

你是如何来使用 yarn 的呢?欢迎分享你的经验。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

相关参考

npm https://docs.npmjs.com
yarn https://yarnpkg.com

Javascript 相关文章推荐
图片按比例缩放函数
Jun 26 Javascript
jquery.blockUI.js上传滚动等待效果实现思路及代码
Mar 18 Javascript
javascript图片切换综合实例(循环切换、顺序切换)
Jan 13 Javascript
Web前端新人笔记之jquery入门心得(新手必看)
May 17 Javascript
Vue.js每天必学之计算属性computed与$watch
Sep 05 Javascript
jQuery监听文件上传实现进度条效果的方法
Oct 16 Javascript
Bootstrap Modal遮罩弹出层代码分享
Nov 21 Javascript
vue框架搭建之axios使用教程
Jul 11 Javascript
JavaScript设计模式之模板方法模式原理与用法示例
Aug 07 Javascript
VuePress 静态网站生成方法步骤
Feb 14 Javascript
layui 上传文件_批量导入数据UI的方法
Sep 23 Javascript
小程序怎样让wx.navigateBack更好用的方法实现
Nov 01 Javascript
JS实现匀加速与匀减速运动的方法示例
Sep 04 #Javascript
node-sass安装失败的原因与解决方法
Sep 04 #Javascript
使用MUI框架模拟手机端的下拉刷新和上拉加载功能
Sep 04 #Javascript
JS图片延迟加载插件LazyImgv1.0用法分析【附demo源码下载】
Sep 04 #Javascript
React教程之Props验证的具体用法(Props Validation)
Sep 04 #Javascript
VueJS组件之间通过props交互及验证的方式
Sep 04 #Javascript
vue中component组件的props使用详解
Sep 04 #Javascript
You might like
无数据库的详细域名查询程序PHP版(3)
2006/10/09 PHP
PHP判断是否有Get参数的方法
2014/05/05 PHP
一段实用的php验证码函数
2016/05/19 PHP
Laravel中的Auth模块详解
2017/08/17 PHP
Extjs中常用表单介绍与应用
2010/06/07 Javascript
jQuery学习笔记之DOM对象和jQuery对象
2010/12/22 Javascript
jQuery 常见操作实现方式和常用函数方法总结
2011/05/06 Javascript
精通Javascript系列之数值计算
2011/06/07 Javascript
网页禁用右键菜单和鼠标拖动选择方法小结
2015/02/25 Javascript
JavaScript模拟数组合并concat
2016/03/06 Javascript
轻松掌握JavaScript中的Math object数学对象
2016/05/26 Javascript
Javascript 创建类并动态添加属性及方法的简单实现
2016/10/20 Javascript
微信小程序 wx.uploadFile无法上传解决办法
2016/12/14 Javascript
Jquery与Bootstrap实现后台管理页面增删改查功能示例
2017/01/22 Javascript
vue+axios 前端实现登录拦截的两种方式(路由拦截、http拦截)
2018/10/24 Javascript
vue.js指令v-for使用以及下标索引的获取
2019/01/31 Javascript
python实现多线程抓取知乎用户
2016/12/12 Python
python os用法总结
2018/06/08 Python
Flask框架WTForm表单用法示例
2018/07/20 Python
PyTorch的深度学习入门教程之构建神经网络
2019/06/27 Python
详解python中eval函数的作用
2019/10/22 Python
python实现大战外星人小游戏实例代码
2019/12/26 Python
python GUI库图形界面开发之PyQt5信号与槽基本操作
2020/02/25 Python
pandas分组聚合详解
2020/04/10 Python
Python如何把字典写入到CSV文件的方法示例
2020/08/23 Python
梅西酒窖:Macy’s Wine Cellar
2018/01/07 全球购物
党员党性分析材料
2014/02/17 职场文书
中考冲刺决心书
2014/03/11 职场文书
高中学校对照检查材料
2014/08/31 职场文书
一份关于丢失公司财物的检讨书
2014/09/19 职场文书
专业技术职务聘任证明
2015/03/02 职场文书
医务人员医德考评自我评价
2015/03/03 职场文书
2015年服务员个人工作总结
2015/05/27 职场文书
html5调用摄像头实例代码
2021/06/28 HTML / CSS
浅谈MySQL之select优化方案
2021/08/07 MySQL
div与span之间的区别与使用介绍
2021/12/06 HTML / CSS