yarn 和 npm 一样也是 JavaScript 包管理工具,下面本篇文章就来带大家了解一下yarn包管理工具,希望对大家有所帮助!
1. yarn简介
Yarn
是 facebook
发布的一款取代 npm
的包管理工具
- 速度超快 ——
Yarn
缓存了每个下载过的包,所以再次使用时无需重复下载。 同时利用并行下载以最大化资源利用率,因此安装速度更快 - 超级安全 —— 在执行代码之前,
Yarn
会通过算法校验每个安装包的完整性 - 超级可靠 —— 使用详细、简洁的锁文件格式和明确的安装算法,
Yarn
能够保证在不同系统上无差异的工作
2. yarn安装与更新
2-1 全局安装
通过 npm install -g
全局去安装 yarn
包管理工具,默认安装的版本是 yarn 1
版本
# 全局安装 npm install -g yarn # 查看yran安装版本 yarn --version # 显示命令列表 yarn help
2-2 项目安装
在项目中需要使用 yarn 2
,可以在项目更目录安装333
“Berry” 是 Yarn 2 发布序列的代号,同时也是我们的 代码仓库 的名称!
yarn set version berry
2-3 yarn更新
将 yarn
更新到最新版本,yarn
会从我们的网站下载最新的二进制文件,并将其安装在您的项目中
将项目中的包管理工具升级为
Yarn 2
,此后如果需要对此Yarn 2
进行升级,则可以使用yarn set version latest
进行升级,否则仍是对Yarn 1
进行操作
yarn set version latest
2-4 安装maste分支最新版
尝试最新的 master
代码分支
yarn set version from sources
可以使用 --branch
参数来指定要安装特定的分支节点
yarn set version from sources --branch 1211
3. 镜像管理
3-1 安装淘宝镜像
修改国内镜像后可以加快软件包安装速度
查看当前使用的镜像
yarn config get registry
添加 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/
3-2 yrm镜像管理
yrm
是管理镜像的工具,可以列出可以使用的镜像,非常方便
安装 yrm
npm install -g yrm
列出可以使用的镜像
yrm ls
使用淘宝镜像
yrm use taobao
测试镜像速度
yrm test taobao
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.
{ "name": "yarn-init", "version": "1.0.0", "description": "初始化配置", "main": "index.js", "author": "jsx <2738389567@qq.com> (https://github.com/xiaofeilalala)", "license": "MIT" }
4-2 设置配置项
通过 yarn config
去设置显示删除配置项
yarn config list // 显示所有配置项 yarn config get <key> //显示某配置项 yarn config delete <key> //删除某配置项 yarn config set <key> <value> [-g|--global] //设置配置项
4-3 安装依赖
安装所有依赖
yarn install
强制重新下载所有包
yarn install --force
添加依赖项,会自动更新到 package.json
和 yarn.lock
文件中
# 安装最新版本 yarn add [packageName] # 安装指定版本 yarn add [packageName]@<version> # 安装指定tag版本 beta,next或者latest yarn add [packageName]@<tag>
安装包的精确版本,例如: yarn add foo@1.2.3
会接受 1.9.1
版本,但是 yarn add foo@1.2.3 --exact
只能安装指定 1.2.3
版本
yarn add [packageName]@<version> --exact yarn add [packageName]@<version> -E
安装包的次要版本里的最新版,例如:yarn add foo@1.2.3 --title
会接受 1.2.9
,但不接受 1.3.0
yarn add [packageName]@<version> --title yarn add [packageName]@<version> -T
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
4-5 升级依赖
根据需要将安装好的依赖包进行升级
# 更新所有软件包 yarn up # 升级到最新版本 yarn up [packageName] # 升级到指定版本 yarn up [packageName]@[version] # 升级到指定tag版本 yarn up [packageName]@[tag]
4-6 删除依赖
从项目中删除依赖项 dependencies
,会自动更新 package.json
和 yarn.lock
yarn remove [packageName]
删除 yarn
全局软件包
yarn remove -g [packageName]
4-7 发布模块
yarn publish
用于将当前模块发布到 http://npmjs.com
如果已经注册过,就使用下面的命令登录
yarn login
退出登录 npm
仓库
yarn logout
登录以后,就可以使用 npm publish
命令发布
yarn publish
撤销发布的模块 npm unpublish
# 删除某个版本 yarn unpublish [packageName]@<version> # 删除整个npm市场的包 yarn unpublish [packageName] --force
4-8 运行命令
yarn run
用来执行在 package.json
中 scripts
属性下定义的脚本
// package.json { "scripts": { "dev": "node app.js", "start": "node app.js" } }
yarn
与 npm
一样 可以有 yarn start
和 yarn test
两个简写的运行脚本方式
# yarn 执行 dev 对应的脚本 node app.js yarn run dev npm run yarn start # yarn npm start # npm
4-9 缓存控制
列出已缓存的每个包
yarn cache list
全局缓存位置
yarn cache dir
清除缓存
yarn cache clean
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
更多编程相关知识,请访问:编程视频!!
以上是一文浅析JS包管理工具:yarn的详细内容。更多信息请关注PHP中文网其他相关文章!

JavaScript在Web开发中的主要用途包括客户端交互、表单验证和异步通信。1)通过DOM操作实现动态内容更新和用户交互;2)在用户提交数据前进行客户端验证,提高用户体验;3)通过AJAX技术实现与服务器的无刷新通信。

理解JavaScript引擎内部工作原理对开发者重要,因为它能帮助编写更高效的代码并理解性能瓶颈和优化策略。1)引擎的工作流程包括解析、编译和执行三个阶段;2)执行过程中,引擎会进行动态优化,如内联缓存和隐藏类;3)最佳实践包括避免全局变量、优化循环、使用const和let,以及避免过度使用闭包。

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

JavaScript在现实世界中的应用包括服务器端编程、移动应用开发和物联网控制:1.通过Node.js实现服务器端编程,适用于高并发请求处理。2.通过ReactNative进行移动应用开发,支持跨平台部署。3.通过Johnny-Five库用于物联网设备控制,适用于硬件交互。

我使用您的日常技术工具构建了功能性的多租户SaaS应用程序(一个Edtech应用程序),您可以做同样的事情。 首先,什么是多租户SaaS应用程序? 多租户SaaS应用程序可让您从唱歌中为多个客户提供服务


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver Mac版
视觉化网页开发工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

WebStorm Mac版
好用的JavaScript开发工具