什么是yarn,如何使⽤yarn安装项⽬依赖
⼀、yarn的简介:
Yarn是facebook发布的⼀款取代npm的包管理⼯具。
⼆、yarn的特点:
1.速度超快。
Yarn 缓存了每个下载过的包,所以再次使⽤时⽆需重复下载。同时利⽤并⾏下载以最⼤化资源利⽤率,因此安装速度更快。
2.超级安全。
在执⾏代码之前,Yarn 会通过算法校验每个安装包的完整性。
3.超级可靠。
使⽤详细、简洁的锁⽂件格式和明确的安装算法,Yarn 能够保证在不同系统上⽆差异的⼯作。
三、yarn的安装:
下载node.js,使⽤npm安装
npm install -g yarn
查看版本:
yarn --version
Yarn 淘宝源安装
四、yarn的常⽤命令:
安装yarn
npm install -g yarn
安装成功后,查看版本号:
yarn --version
创建⽂件夹 yarn
md yarn
进⼊yarn⽂件夹
cd yarn
初始化项⽬
yarn init // 同npm init,执⾏输⼊信息后,会⽣成package.json⽂件
yarn的配置项:
yarn config list // 显⽰所有配置项
yarn config get //显⽰某配置项
yarn config delete //删除某配置项
yarn config set [-g|--global] //设置配置项
安装包:
yarn install ,并将包及它的所有依赖项保存进yarn.lock
yarn install --flat //安装⼀个包的单⼀版本
yarn install --force //强制重新下载所有包
yarn install --production //只安装dependencies⾥的包
yarn install --no-lockfile
yarn install --pure-lockfile
添加包(会更新package.json和yarn.lock):
yarn add [package] // 在当前的项⽬中添加⼀个依赖包,会⾃动更新到package.json和yarn.lock⽂件中
yarn add [package]@[version] // 安装指定版本,这⾥指的是主要版本,如果需要精确到⼩版本,使⽤-E参数
yarn add [package]@[tag] // 安装某个tag(⽐如beta,next或者latest)
//不指定依赖类型默认安装到dependencies⾥,你也可以指定依赖类型:
yarn add --dev/-D // 加到 devDependencies
yarn add --peer/-P // 加到 peerDependencies
yarn add --optional/-O // 加到 optionalDependencies
//默认安装包的主要版本⾥的最新版本,下⾯两个命令可以指定版本:
yarn add --exact/-E // 安装包的精确版本。例如yarn add foo@1.2.3会接受1.9.1版,但是yarn add foo@1.2.3 --exact只会接受1.2.3版yarn add --tilde/-T // 安装包的次要版本⾥的最新版。例如yarn add foo@1.2.3 --tilde会接受1.2.9,但不接受1.3.0
发布包
yarn publish
移除⼀个包
yarn remove :移除⼀个包,会⾃动更新package.json和yarn.lock
更新⼀个依赖
yarn upgrade ⽤于更新包到基于规范范围的最新版本
运⾏脚本
yarn run ⽤来执⾏在 package.json 中 scripts 属性下定义的脚本
显⽰某个包的信息
yarn info 可以⽤来查看某个模块的最新版本信息
缓存
yarn cache
yarn cache list # 列出已缓存的每个包
yarn cache dir # 返回全局缓存位置
yarn cache clean # 清除缓存
五、npm 与 yarn命令⽐较:
⽐如说你的项⽬模块依赖是图中描述的,@1.2.1代表这个模块的版本。在你安装A的时候需要安装依赖C和D,很多依赖不会指定版本号,默认会安装最新的版本,这样就会出现问题:⽐如今天安装模块的时候C和D是某⼀个版本,⽽当以后C、D更新的时候,再次安装模块就会安装C和D的最新版本,如果新的版本⽆法兼容你的项⽬,你的程序可能就会出BUG,甚⾄⽆法运⾏。这就是npm的弊端,⽽yarn为了解决这个问题推出了yarn.lock的机制,这是作者项⽬中的yarn.lock⽂件。
⼤家会看到,这个⽂件已经把依赖模块的版本号全部锁定,当你执⾏yarn install的时候,yarn会读取这个⽂件获得依赖的版本号,然后依照这个版本号去安装对应的依赖模块,这样依赖就会被锁定,以后再也不⽤担⼼版本号的问题了。其他⼈或者其他环境下使⽤的时候,把这个yarn.lock拷贝到相应的环境项⽬下再安装即可。
注意:这个⽂件不要⼿动修改它,当你使⽤⼀些操作如yarn add时,yarn会⾃动更新yarn.lock。