每次切项目都要改 Node 版本?macOS 自动化读取.nvmrc,解放双手!

最近开发项目比较多, 有最新的技术 vite7+react9, 也有很老的技术webpack3+vite2, 这个老项目需要用node12, 我新项目用的node24, 都会想着用nvm做版本管理, 我也不例外, 不过nvm也需要用命令手动切换, 好麻烦, 没办法我太懒了, 不想动, 因此我就想到了用.nvmrc配置node版本, 不过它也需要手动执行nvm use, 不过可以不用带版本号了, 终于可以偷偷懒了, 但是我更懒, 想一点都不想动。因此我找到了现在的方法 zsh-hook, 下面我们一步步来学习一下。因为我现在使用的是macos, 因此这里只主要介绍macos方案。

nvm安装

  1. 下载
bash 复制代码
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.3/install.sh | bash

bash 复制代码
wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.3/install.sh | bash
  1. 配置环境变量
bash 复制代码
vim ~/.zshrc
# 如果喜欢用vscode也可以用vscode打开
code ~/.zshrc

然后将下面内容复制到文件里面

bash 复制代码
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
  1. 重新加载终端
bash 复制代码
source ~/.zshrc

开发zsh hook

注: 还是写在.zshrc文件中, 和上面方法一样, 保存后仍要执行source ~/.zshrc

bash 复制代码
# 自动切换 Node.js 版本
autoload -U add-zsh-hook

function nvm-auto-switch() {
  if [[ -f .nvmrc ]]; then
    local nvmrc_version=$(cat .nvmrc)
    local current_version=$(nvm current)

    if [[ ! "$current_version" =~ ^"$nvmrc_version" ]]; then
      echo "当前版本: $current_version"
      echo "需要切换到版本: $nvmrc_version"
      nvm use
    fi
  fi
}

add-zsh-hook chpwd nvm-auto-switch

nvm-auto-switch

最后, 你需要自动切换的项目中需要加入.nvmrc文件, 里面只需要写版本号, 例如v12, 或者详细点v12.1.1,这样你就可以根据不同项目自动切换node版本啦!

相关推荐
答案answer3 分钟前
three.js着色器(Shader)实现数字孪生项目中常见的特效
前端·three.js
城管不管7 分钟前
SpringBoot与反射
java·开发语言·前端
JackJiang12 分钟前
即时通讯安全篇(三):一文读懂常用加解密算法与网络通讯安全
前端
一直_在路上15 分钟前
Go架构师实战:玩转缓存,击破医疗IT百万QPS与“三大天灾
前端·面试
早八睡不醒午觉睡不够的程序猿20 分钟前
Vue DevTools 调试提示
前端·javascript·vue.js
恋猫de小郭23 分钟前
基于 Dart 的 Terminal UI ,pixel_prompt 这个 TUI 库了解下
android·前端·flutter
天天向上102423 分钟前
vue el-form 自定义校验, 校验用户名调接口查重
前端·javascript·vue.js
忧郁的蛋~25 分钟前
前端实现网页水印防移除的实战方案
前端
喝奶茶的Blair25 分钟前
PHP应用-组件框架&前端模版渲染&三方插件&富文本编辑器&CVE审计(2024小迪安全DAY30笔记)
前端·安全·php
浪潮行舟26 分钟前
WebGIS:在 Vue 2 项目中使用 Mapbox 时,如果需要加载的 GIS 数据量过大,怎么让接口一次性获取的geojson数据分批加载
前端·javascript·vue.js