Skip to content

各平台安装yarn

Mac基于brew安装yarn

bash
brew install yarn

yarn -v

Windows系统使用yarn

说明

从nodejs的16.10版本开始,nodejs安装包就附带了yarn。所以只要你的nodejs版本大于等于16.10,只需要一个命令就可以使用了,非常方便。

启用yarn

注意,必须是管理员权限打开的终端执行下面的命令

bash
# 执行下面的命令启用yarn
corepack enable


C:\Windows\system32>corepack enable

C:\Windows\system32>yarn -v
1.22.15

C:\Windows\system32>

如果你的nodejs版本小于16.10,那么你必须先执行安装corepack后再启用yarn。

bash
npm i -g corepack
corepack enable

更详细的参考:https://yarnpkg.com/getting-started/install

基于yarn+vite创建vue项目

**1. 通过yarn create命令创建一个基于vite+vue3的项目 **

1832671049016147968.png

**2/3. 输入项目名和选择vue **

1832671049544630272.png

4. 选择JavaScript语言实现的vue

而typescript是微软搞的一个相当于是JavaScript的超集的一个语言,对它没了解的,我们还是踏实的选择JavaScript语言实现的vue吧。

1832671050177970176.png

完事项目就创建好了,接下来我们只需要下载依赖后,就可以启动项目了:

1832671050794532864.png

前端访问效果:

1832671052874907648.png

常见报错

Internal Error: EPERM: operation not permitted, open 'C:\software\nodejs\pnpm'

windows11 + node-v18.15.0

Windows终端开启yarn时,报错:

1832671054124810240.png

解决办法也在上图中。

Command 'yarn' not found, but can be installed with:

ubuntu2004 + npm8.19.2

使用yarn创建vite报错:

(base) moluo@ubuntu:~/Desktop/luffycity$ yarn create vite

Command 'yarn' not found, but can be installed with:

sudo apt install cmdtest

这是因为没有下载yarn或者下载的有问题导致的。

我们可以:

# 卸载掉原来的yarn
(base) moluo@ubuntu:~/Desktop/luffycity$ sudo apt remove cmdtest yarn -y

# 重新安装
(base) moluo@ubuntu:~/Desktop/luffycity$ npm install -g yarn

# 完事之后,记得重新打开一个新的终端,测试是否安装成功
(base) moluo@ubuntu:~/Desktop/luffycity$ yarn --version
1.22.19

error create-vite@3.1.0: The engine "node" is incompatible with this module. Expected version "^14.18.0 || >=16.0.0". Got "14.16.0"

ubuntu2004 + npm8.19.2

使用yarn create vite时报错:

(base) moluo@ubuntu:~/Desktop/luffycity$ yarn create vite
yarn create v1.22.19
[1/4] Resolving packages...
[2/4] Fetching packages...
error create-vite@3.1.0: The engine "node" is incompatible with this module. Expected version "^14.18.0 || >=16.0.0". Got "14.16.0"
error Found incompatible module.
info Visit https://yarnpkg.com/en/docs/cli/create for documentation about this command.

根据报错内容,我们发现是node版本比较低,必须大于14.18.0,而我们此时的node版本是14.16.0,来测试下:

bash
(base) moluo@ubuntu:~/Desktop/luffycity$ node -v
v14.16.0

所以,我们可以通过nvm来搞个最新的node版本,并且切换过去,就行了。

bash
# 查看所有的node版本
nvm ls-remote

# 然后下载一个新的node版本,我这里以18.10.0为例
nvm install 18.10.0 

# 下载完,要use使用这个版本
nvm use 18.10.0 

# 然后node -v确认下
(base) moluo@ubuntu:~/Desktop/luffycity$ node -v
v18.10.0

# npm也没问题
(base) moluo@ubuntu:~/Desktop/luffycity$ npm -v
8.19.2

# 由于当前使用这个18.10.0版本的node是新的,啥都需要手动从新配置,所以yarn还需要我们手动再配置一下,如果你习惯使用cnpm的话,也需要你手动配置
(base) moluo@ubuntu:~/Desktop/luffycity$ npm install -g yarn

added 1 package in 2s

# 测一下,看看有没有问题
(base) moluo@ubuntu:~/Desktop/luffycity$ yarn -v
1.22.19

00h00m00s 0/0: : ERROR: [Errno 2] No such file or directory: 'create'

这个是在使用yarn create命令时报的错。

1832671054426800128.png

其原因就是node版本低,截图中的版本应该是node14.16.0的版本吧,忘了截图了,这个版本的node使用npm安装yarn之后,就不好使。

所以我们使用nvm来下载一个高版本的node,然后在下载yarn,再用yarn create就没啥问题了。

bash
# 1. 使用nvm安装node18.10.0
nvm install 18.10.0

# 2. 使用nvm切换当前node版本为18.10.0
nvm use 18.10.0

# 2.1 切换之后,可以使用下面几个命令看下能否正常返回版本号
node -v
npm -v

# 3. 上面两步没问题之后,就可以通过npm命令安装yarn了
npm install yarn -g

# 3.1 成功之后,就可以通过下面命令测试
yarn -v

# 4. 上面几个步骤都没问题之后,就可以再重新尝试yarn create命令了
yarn create vite

yarn create vite时,报SyntaxError:Unexdected token '.'的错误

ubuntu20.04

终端通过yarn创建vite项目时,报错:

1832671055156609024.png

我发现用的node是12版本,所以这个解决方式就是安装nvm,再通过nvm安装新版的node,比如18版本的,然后再重新执行yarn命令创建vite项目。

安装nvm的过程

参考nvm的github官档:https://github.com/nvm-sh/nvm,使用下面的命令安装nvm:

bash
# 先安装 curl
sudo apt install curl

# 在按照官档建议的命令安装
(base) twq@twq-virtual-machine:~/Desktop/luffeicity$ curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.37.0/install.sh | bash
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0
curl: (7) Failed to connect to raw.githubusercontent.com port 443 after 15 ms: Couldn't connect to server

结果报错了...........

解决方式,就是按照官档采用git安装,注意,官档建议git版本必须大于 v1.7.10+,我这里符合条件,所以,执行下面的安装命令:

bash
(base) twq@twq-virtual-machine:~/Desktop/luffeicity$ git --version
git version 2.34.1

# 然后执行下面的命令
cd ~/
git clone https://github.com/nvm-sh/nvm.git .nvm
git checkout v0.39.5
. ./nvm.sh

# 添加环境变量
sudo vim ~/.bashrc

# 打开的文件中,在最后,追加这些内容
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"  # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion"

# source一下,使其生效
source ~/.bashrc
# 接下来就可以测试了
(base) twq@twq-virtual-machine:~/.nvm$ nvm -v
0.39.5

安装成功。

附赠的命令,安装node18版本的,我写这个博客时,node最新的lts版本是18.17.1,所以,我这么做:

bash
nvm install 18.17.1
nvm ls
nvm use 18.17.1

(base) twq@twq-virtual-machine:~/.nvm$ node -v
v18.17.1
(base) twq@twq-virtual-machine:~/.nvm$ npm -v
9.6.7
(base) twq@twq-virtual-machine:~/.nvm$ yarn -v
1.22.19

完事之后,再用yarn命令从新create就好了。

warning package-lock.json found. Your project contains lock files generated by tools other than Yarn. It is error Error: certificate has expired

win11 yarn1.22.21 node18.15.0

使用yarn add三方包时报错:

bash
(base) D:\BaiduSyncdisk\wangzhangkai>yarn add vitepress
yarn add v1.22.21
warning package-lock.json found. Your project contains lock files generated by tools other than Yarn. It is error Error: certificate has expired
    at TLSSocket.onConnectSecure (node:_tls_wrap:1540:34)
    at TLSSocket.emit (node:events:513:28)
    at TLSSocket._finishInit (node:_tls_wrap:959:8)
    at ssl.onhandshakedone (node:_tls_wrap:743:12)
info Visit https://yarnpkg.com/en/docs/cli/add for documentation about this command.

解决办法,手动删除项目根目录下的package-lock.json文件,然后终端运行:

bash
yarn install --ignore-engines

error Error: certificate has expired

win11 yarn1.22.21 node18.15.0

使用yarn add三方包时报错:

bash
(base) D:\BaiduSyncdisk\wangzhangkai>yarn add vitepress
yarn add v1.22.21
[1/4] Resolving packages...
error Error: certificate has expired
    at TLSSocket.onConnectSecure (node:_tls_wrap:1540:34)
    at TLSSocket.emit (node:events:513:28)
    at TLSSocket._finishInit (node:_tls_wrap:959:8)
    at ssl.onhandshakedone (node:_tls_wrap:743:12)
info Visit https://yarnpkg.com/en/docs/cli/add for documentation about this command.

解决,执行下面命令:

bash
yarn config set "strict-ssl" false -g

然后重新尝试安装模块即可。参考:https://stackoverflow.com/questions/40033794/yarn-unable-to-verify-the-first-certificate -verify-the-first-certificate>