前端学习笔记(2.0)

在做公司的老项目时,第一件事就是对应的将代码拷过来的时候出现的环境的问题。

一般来说,就是拷过来的代码不能直接用,把对应的node_modules文件夹删除,然后直接npm i进行安装对应的库和插件即可。

但是,由于是老项目,所以用到的库和现在电脑上的node版本不一样,所以就导致执行命令npm i的时候报错。

我一开始安装的版本是20版本的,所以这样 就会出现版本不能兼容某些第三方库的依赖,就需要进行node降低【亲测node 16版本是较好的,能够前后兼容,前可适应老项目,后可适应较新的项目,不过要是使用pnpm这些需要node18+,辩证的看,而不是绝对的】

所以就想起了使用nvm,简单介绍一下NVM.

NVM(Node Version Manager)是一个专门用于管理Node.js版本的工具。以下是对NVM的详细介绍:

一、功能特点

  1. 多版本管理:NVM允许用户在同一台计算机上安装和切换多个版本的Node.js。这对于需要处理不同项目、每个项目依赖不同Node.js版本的开发者来说非常有用。
  2. 简便易用:通过简单的命令行指令,用户可以轻松安装、切换、卸载和查看已安装的Node.js版本。
  3. 避免冲突:NVM为每个Node.js版本创建了一个独立的环境,避免了不同版本之间的冲突。
  4. 无需管理员权限:在某些情况下,全局安装Node.js可能需要管理员权限,这可能导致权限问题。使用NVM,用户可以在用户的主目录下安装Node.js,无需管理员权限。

那么,在安装nvm之前,需要将自己电脑中之前安装的node给卸载掉,否则nvm安装不成功。

卸载掉之后,来到nvm对应的github网址,就可以找到下载链接:https://github.com/coreybutler/nvm-windows/releases/download/1.1.12/nvm-setup.zip

根据链接中选择版本号直接进入即可【提示:进不去的要科学上网,自行找某盘链接就可以了】

我下载的是1.1.11

安装过程就不再展示了,安装完毕后查看是否安装成功

npm --version

然后可以使用nvm install 版本号进行安装即可

bash 复制代码
nvm install 14.17.0

这时我们可以安装多个版本的node,具体使用哪个我们先进行查看

然后使用命令nvm use 版本号即可

这样我们在使用nvm list查看已安装的node后,对应的版本号前面会有一个*号。

这样我们的node低版本就已经使用完毕了,我们直接验证

然后我们再来到老项目中使用npm i就可以了。

这里额外列出我在没有使用老版本node的时候使用npm i 出现的错误

然后根据网上的办法进行忽略依赖

然后清理缓存

还是没有解决,由于项目中的各种包之间的依赖过于复杂,所以还是直接采用node降级比较省事,要不然无论是提醒的package.lock文件中的哪个哪个包下载失败,还是不支持了,然后搜索答案让你切换镜像源啥的都不好使,就会出现各种各样的bug。。。。。。项目还没开始做,就卡在环境下,心态都崩了。

补充:

nvm 查看node版本命令
查看node列表命令
nvm安装node镜像配置

安装的node就会在这里展示,对应的配置文件就是setting.txt

打开,并配置如下:

bash 复制代码
root: C:\Users\10834\AppData\Roaming\nvm
path: C:\Program Files\nodejs
node_mirror: https://npmmirror.com/mirrors/node/
npm_mirror:  https://npmmirror.com/mirrors/npm/

这样就配置完成了,然后我们就可以愉快的进行开发了,` ~ `

相关推荐
脑袋大大的7 分钟前
判断当前是否为钉钉环境
开发语言·前端·javascript·钉钉·企业应用开发
军军君0116 分钟前
基于Springboot+UniApp+Ai实现模拟面试小工具二:后端项目搭建
前端·javascript·spring boot·spring·微信小程序·前端框架·集成学习
Wy. Lsy34 分钟前
Kotlin基础学习记录
开发语言·学习·kotlin
The_Killer.38 分钟前
格密码--数学基础--06对偶空间与对偶格
学习·线性代数·密码学
quweiie1 小时前
tp8.0\jwt接口安全验证
前端·安全·jwt·thinkphp
Andy杨1 小时前
20250712-1-Kubernetes 监控与日志管理-K8s日志管理与维护_笔记
笔记·容器·kubernetes
xiaoyan20151 小时前
最新Flutter3.32+Dart3仿微信App聊天实例
前端·flutter·dart
撰卢1 小时前
【个人笔记】负载均衡
运维·笔记·负载均衡
汪敏wangmin2 小时前
Fiddler-抓包后直接生成Loadrunner脚本或者Jmeter脚本
前端·jmeter·fiddler
栈溢出了2 小时前
MyBatis实现分页查询-苍穹外卖笔记
java·笔记·mybatis