使用nvm解决nodejs多版本问题,难道不香吗?

引言

生活从不亏待每一个努力向上的人,未来的幸运都是过往努力的积攒。
趁阳光正好,做你想做的事;趁你年轻,去追逐梦想!

起因

有天,在运行一个vue项目的时候,不知道用的nodejs版本是多少,直接使用我电脑的14版本的运行。当我使用 npm install运行的时候,报错了,具体错误不知道。大概意思就是说,我电脑环境的nodejs版本和项目需要用的nodejs版本不一致导致的,需要使用22版本的。

随后,我下载了22版本的nodejs进行安装,配置环境变量,运行项目,执行npm install,运行成功。

但是,发现了一个问题,这个项目是用22版本的,但是还有其他项目是用低版本的,这个怎么办呢?这个时候,我发现了一个好东西 nvm 。它的作用是啥呢?nvm 是nodejs的版本管理工具,可以解决nodejs各版本之间不兼容现象,可通过它安装和切换不同版本的nodejs。 是不是感觉很哇塞呢?

看到这块,就可解决我的问题,接下来就是我们下载安装调试的过程了。

开始实战

检查

主要针对于之前安装过nodejs,需要进行以下操作:

1.卸载nodejs,可通过控制面板进行删除

2.删除环境变量,删除环境变量中系统和用户中path的nodejs路径。

下载安装

1.打开下载界面,选择对应nvm安装包。

2.这里为了避免出现问题,选择使用1.1.12版本进行下载安装。安装的时候可根据自身情况,设置nvm和nodejs安装路径。

3.安装之后,使用命令nvm -v,进行是否安装成功。

4.设置国内阿里云镜像,加速npm依赖包。

打开nvm安装目录的setting.txt,复制以下,保存关闭。

ruby 复制代码
nvm npm_mirror https://npmmirror.com/mirrors/npm/  
nvm node_mirror https://npmmirror.com/mirrors/node/

5.查看nodejs版本,nvm list available

可访问node官方,查看我们所需要的版本,记住版本号,可接下来使用。

下载多个版本

1.使用命令 nvm install 版本号,进行下载安装。这里选用22.14.0和14.20.0。

安装22.14.0

安装14.20.0

2.进行版本使用,使用命令 nvm use 版本号

nvm use 22.14.0

nvm use 14.20.0

3.查看当前node版本和npm版本

复制代码
node -v 
npm-v

4.使用cmd可修改node默认的全局模块安装global路径和cache路径。

swift 复制代码
npm config set prefix "D:\service\NodeJs\node_global" 
npm config set cache "D:\service\NodeJs\node_cache"

注意

1.记得在cmd下载node并设置好之后,需要重启一下编辑器,要不然有可能会出现以下错误:

arduino 复制代码
# npm : 无法将"npm"项识别为 cmdlet、函数、脚本文件或可运行程序的名称。

总结

至此,nvm实现nodejs多版本功能已经实现,有需要的可以前去尝试了!

nvm官网地址

nvm.uihtm.com/

展望

多一点快乐,少一点烦恼。每天开心笑,累了就睡觉,醒了就微笑,生活就是这么简单。
没有白费的努力,也没有碰巧的成功。只要认真对待生活,终有一天,你的每一份努力都将绚烂成花。

相关推荐
OpenTiny社区8 分钟前
开源之夏报名倒计时3天!还有9个前端任务有余位,快来申请吧~
前端·github
ak啊13 分钟前
WebGL魔法:从立方体到逼真阴影的奇妙之旅
前端·webgl
hang_bro24 分钟前
使用js方法实现阻止按钮的默认点击事件&触发默认事件
前端·react.js·html
用户907387036486432 分钟前
pnpm是如何解决幻影依赖的?
前端
树上有只程序猿38 分钟前
Claude 4提升码农生产力的5种高级方式
前端
傻球39 分钟前
没想到干前端2年了还能用上高中物理运动学知识
前端·react.js·开源
咚咚咚ddd39 分钟前
前端组件:pc端通用新手引导组件最佳实践(React)
前端·react.js
Lazy_zheng40 分钟前
🚀 前端开发福音:用 json-server 快速搭建本地 Mock 数据服务
前端·javascript·vue.js
HJ_Coder40 分钟前
基于Proxyman的实时解密和预览方案
前端
Gixy41 分钟前
聊聊纯函数与不可变数据结构
前端·设计模式