最近创建了一个公众号:编程进阶录
,记录一些自己学习过程当中的笔记和心得,欢迎大家关注
最近看到一篇文章登上了热榜,我阅读了一下,发现这不还是在手动切换吗?所以,我准备和大家介绍一种自动切换的 node 版本的工具,不是
vscode
插件!不是vscode
插件!不是vscode
插件!这篇文章的灵感也是来源于这篇文章😄: # 🤔公司实习生居然还在手动切换node版本?
0⃣️ 效果展示
先看一下效果,z
这个命令你可以理解为 cd
,也就是方便我快速的切换目录。
1⃣️ 准备
这里我需要先声明一下全自动切换 node
版本的条件。
- 你使用的电脑需要是能够安装
zsh
和oh-my-zsh
的,oh-my-zsh
对系统的兼容性,如下图所示,windows
的话还是用WSL
作为开发环境比较好。
- 然后就是你电脑上已经成功安装好了
nvm
,如果你还没有安装,可以参照下面这行命令进行安装
bash
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash
或者
bash
wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash
验证是否成功安装的话你可以打开终端,在命令行当中输入命令
bash
nvm --version
出现如下图所示的内容,表示已经成功安装了 nvm
。
可能会在执行命令之后,还需要设置 linux 的环境变量,直接按照官方源码仓库当中的 README
设置即可。
即将下面这行 shell 命令,添加到你的 ~/.zshrc
当中,因为我们需要借助 zsh 插件,所以使用的是 zsh
,命令的含义就是在你的系统当中设置一个 $NVM_DIR
的环境变量。
shell
export NVM_DIR="$([ -z "${XDG_CONFIG_HOME-}" ] && printf %s "${HOME}/.nvm" || printf %s "${XDG_CONFIG_HOME}/nvm")"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
2⃣️ 实现自动切换 node
如果你已经成功的安装了 zsh
和 oh-my-zsh
,接下来需要借助一个一个 oh-my-zsh
的插件,这个插件是已经内置在 oh-my-zsh
当中了的。
也就是 nvm
对应的 oh-my-zsh
插件。
修改你的 .zshrc
文件,这个文件一般在你的用户目录下,在命令行直接输入下面这两行命令开始配置你的 zshrc
。
bash
cd ~
vim .zshrc
你也可以不使用 vim
,选择一个你喜欢的编辑器就好。
将下面的配置加入到你的配置当中.
代码如下:
zsh
plugins=(git z nvm zsh-syntax-highlighting zsh-autosuggestions)
zstyle ':omz:plugins:nvm' lazy yes
zstyle ':omz:plugins:nvm' autoload yes
zstyle ':omz:plugins:nvm' silent-autoload yes
上面的 plugins 包含了 nvm
插件,也还有一些 zsh
的常用插件,自行搜索安装即可,如果你有什么不懂的地方,也欢迎关注我的公众号和我私聊,帮你解决问题。
如果你已经做好了上面的工作,执行一下下面这条命令,让我们修改过的 .zshrc
起效果。
bash
source .zshrc
还有最后一点,默认情况下需要设置一个默认使用的 node
,因为上面的方法实现 node
版本的自动切换,需要借助项目下的 .nvmrc
文件。
.nvmrc
一般是一个纯文本文件,记录了项目需要使用的 node
的版本号。如下图所示:
接下来你只需要给你的项目增加一个 .nvmrc
配置,在终端下就可以自动根据你项目配置的 node 版本自动进行切换了,如果项目所需要的 node
版本不存在, 这个工具还能够自动使用 nvm 下载对应的版本。
3⃣️ 注意事项
为了让有更好的开发体验,应该给我们的电脑配置一个默认的 node
版本,因为不是所有的项目都会有 .nvmrc
文件,如果不存在,就能够自动使用我们设置好的默认版本。
给 nvm
设置默认版本 node
命令如下:
bash
nvm alias default [版本号] # [版本号]替换成你需要使用的 node 的版本号,如 v18.8.2