一文浅析JS包管理工具:yarn

青灯夜游
Lepaskan: 2022-08-09 15:51:48
ke hadapan
2248 orang telah melayarinya

yarn 和 npm 一样也是 JavaScript 包管理工具,下面本篇文章就来带大家了解一下yarn包管理工具,希望对大家有所帮助!

一文浅析JS包管理工具:yarn

1. yarn简介

Yarnfacebook发布的一款取代npm的包管理工具

  • 速度超快 ——Yarn缓存了每个下载过的包,所以再次使用时无需重复下载。 同时利用并行下载以最大化资源利用率,因此安装速度更快
  • 超级安全 —— 在执行代码之前,Yarn会通过算法校验每个安装包的完整性
  • 超级可靠 —— 使用详细、简洁的锁文件格式和明确的安装算法,Yarn能够保证在不同系统上无差异的工作

2. yarn安装与更新

2-1 全局安装

通过npm install -g全局去安装yarn包管理工具,默认安装的版本是yarn 1版本

# 全局安装 npm install -g yarn # 查看yran安装版本 yarn --version # 显示命令列表 yarn help
Salin selepas log masuk

2-2 项目安装

在项目中需要使用yarn 2,可以在项目更目录安装333

“Berry” 是 Yarn 2 发布序列的代号,同时也是我们的代码仓库的名称!

yarn set version berry
Salin selepas log masuk

2-3 yarn更新

yarn更新到最新版本,yarn会从我们的网站下载最新的二进制文件,并将其安装在您的项目中

将项目中的包管理工具升级为Yarn 2,此后如果需要对此Yarn 2进行升级,则可以使用yarn set version latest进行升级,否则仍是对Yarn 1进行操作

yarn set version latest
Salin selepas log masuk

2-4 安装maste分支最新版

尝试最新的master代码分支

yarn set version from sources
Salin selepas log masuk

可以使用--branch参数来指定要安装特定的分支节点

yarn set version from sources --branch 1211
Salin selepas log masuk

3. 镜像管理

3-1 安装淘宝镜像

修改国内镜像后可以加快软件包安装速度

查看当前使用的镜像

yarn config get registry
Salin selepas log masuk

添加yarn的淘宝镜像

yarn config set registry https://registry.npm.taobao.org -g # 恢复默认 yarn config set registry http://registry.npmjs.org/ # 安装sass yarn config set sass_binary_site https://npm.taobao.org/mirrors/node-sass/
Salin selepas log masuk

3-2 yrm镜像管理

yrm是管理镜像的工具,可以列出可以使用的镜像,非常方便

安装yrm

npm install -g yrm
Salin selepas log masuk

列出可以使用的镜像

yrm ls
Salin selepas log masuk

使用淘宝镜像

yrm use taobao
Salin selepas log masuk

测试镜像速度

yrm test taobao
Salin selepas log masuk

4. yarn使用

4-1 初始化项目

yarn init用来初始化生成一个新的package.json文件

D:\My Study\08-Node.js\02-yarn>yarn init yarn init v1.22.19 question name (02-yarn): yarn-init question version (1.0.0): question description: 初始化配置 question entry point (index.js): question repository url: question author (jsx <2738389567@qq.com> (https://github.com/xiaofeilalala)): question license (MIT): question private: success Saved package.json Done in 29.32s.
Salin selepas log masuk
{ "name": "yarn-init", "version": "1.0.0", "description": "初始化配置", "main": "index.js", "author": "jsx <2738389567@qq.com> (https://github.com/xiaofeilalala)", "license": "MIT" }
Salin selepas log masuk

4-2 设置配置项

通过yarn config去设置显示删除配置项

yarn config list // 显示所有配置项 yarn config get  //显示某配置项 yarn config delete  //删除某配置项 yarn config set   [-g|--global] //设置配置项
Salin selepas log masuk

4-3 安装依赖

安装所有依赖

yarn install
Salin selepas log masuk

强制重新下载所有包

yarn install --force
Salin selepas log masuk

添加依赖项,会自动更新到package.jsonyarn.lock文件中

# 安装最新版本 yarn add [packageName] # 安装指定版本 yarn add [packageName]@ # 安装指定tag版本 beta,next或者latest yarn add [packageName]@
Salin selepas log masuk

安装包的精确版本,例如:yarn add foo@1.2.3会接受1.9.1版本,但是yarn add foo@1.2.3 --exact只能安装指定1.2.3版本

yarn add [packageName]@ --exact yarn add [packageName]@ -E
Salin selepas log masuk

安装包的次要版本里的最新版,例如:yarn add foo@1.2.3 --title会接受1.2.9,但不接受1.3.0

yarn add [packageName]@ --title yarn add [packageName]@ -T
Salin selepas log masuk

4-4 不同依赖类

在一个Node.js项目中,package.json几乎是一个必须的文件,它的主要作用就是管理项目中所使用到的外部依赖包,同时它也是npm命令的入口文件

npm目前支持以下几类依赖包管理:

  • dependencies
  • devDependencies
  • peerDependencies
  • optionalDependencies
  • bundledDependencies/bundleDependencies

dependencies

应用依赖,或者叫做业务依赖,这是我们最常用的依赖包管理对象!它用于指定应用依赖的外部包,这些依赖是应用发布后正常执行时所需要的,但不包含测试时或者本地打包时所使用的包。

devDependencies

开发环境依赖,仅次于dependencies的使用频率!它的对象定义和dependencies一样,只不过它里面的包只用于开发环境,不用于生产环境,这些包通常是单元测试或者打包工具等,例如gulp,grunt,webpack,moca,coffee

peerDependencies

同等依赖,或者叫同伴依赖,用于指定当前包(也就是你写的包)兼容的宿主版本。如何理解呢? 试想一下,我们编写一个gulp的插件,而gulp却有多个主版本,我们只想兼容最新的版本,此时就可以用同等依赖(peerDependencies)来指定

optionalDependencies

可选依赖,如果有一些依赖包即使安装失败,项目仍然能够运行或者希望npm继续运行,就可以使用optionalDependencies。另外optionalDependencies会覆盖dependencies中的同名依赖包,所以不要在两个地方都写

bundledDependencies/bundleDependencies

打包依赖,bundledDependencies是一个包含依赖包名的数组对象,在发布时会将这个对象中的包打包到最终的发布包里

不指定依赖类型默认安装到dependencies里,你也可以指定依赖类型

# 添加到 devDependencies 依赖项 yarn add [package]@[version] --dev yarn add [package]@[version] -D # 添加到 peerDependencies 依赖项 yarn add [package]@[version] --peer yarn add [package]@[version] -P # 添加到 optionalDependencies 依赖项 yarn add [package]@[version] --optional yarn add [package]@[version] -O
Salin selepas log masuk

4-5 升级依赖

根据需要将安装好的依赖包进行升级

# 更新所有软件包 yarn up # 升级到最新版本 yarn up [packageName] # 升级到指定版本 yarn up [packageName]@[version] # 升级到指定tag版本 yarn up [packageName]@[tag]
Salin selepas log masuk

4-6 删除依赖

从项目中删除依赖项dependencies,会自动更新package.jsonyarn.lock

yarn remove [packageName]
Salin selepas log masuk

删除yarn全局软件包

yarn remove -g [packageName]
Salin selepas log masuk

4-7 发布模块

yarn publish用于将当前模块发布到 http://npmjs.com

如果已经注册过,就使用下面的命令登录

yarn login
Salin selepas log masuk

退出登录npm仓库

yarn logout
Salin selepas log masuk

登录以后,就可以使用npm publish命令发布

yarn publish
Salin selepas log masuk

撤销发布的模块npm unpublish

# 删除某个版本 yarn unpublish [packageName]@ # 删除整个npm市场的包 yarn unpublish [packageName] --force
Salin selepas log masuk

4-8 运行命令

yarn run用来执行在package.jsonscripts属性下定义的脚本

// package.json { "scripts": { "dev": "node app.js", "start": "node app.js" } }
Salin selepas log masuk

yarnnpm一样 可以有yarn startyarn test两个简写的运行脚本方式

# yarn 执行 dev 对应的脚本 node app.js yarn run dev npm run yarn start # yarn npm start # npm
Salin selepas log masuk

4-9 缓存控制

列出已缓存的每个包

yarn cache list
Salin selepas log masuk

全局缓存位置

yarn cache dir
Salin selepas log masuk

清除缓存

yarn cache clean
Salin selepas log masuk

4-10 模块信息

yarn info可以用来查看某个模块的最新版本信息

yarn info [packageName] # yarn npm info [packageName] # npm yarn info [packageName] --json # 输出 json 格式 npm info [packageName] --json # npm yarn info [packageName] readme # 输出 README 部分 npm info [packageName] readme
Salin selepas log masuk

更多编程相关知识,请访问:编程视频!!

Atas ialah kandungan terperinci 一文浅析JS包管理工具:yarn. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:csdn.net
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!