npm install报错常用解题思路

最近刚接手一个"新"项目,让我很无语。明明是去年起的项目,但是它所用的部分技术栈非常旧,我启动项目,控制台一堆warning报错,然后项目结构也很让我不适应,很多地方都可以用文件夹包一下来方便定位。哎,让我头大!

事情的起源来自于一次依赖安装。因为业务需求,我安装一个第三方库,但是它不支持React16,然后我想着干脆就升到17吧!反正也没什么新特性应该没问题,不用改太多东西。结果终端报错,查看一下果然是那些旧依赖导致的,要是全部将他们升级到对应17的版本工作量太大!更何况有些库根本不维护了,直接选择性无视吧。。。

我的思路如下:

思路1-查看支持的版本

  1. 去官网或GitHub上查看项目所用的框架版本所支持的react版本。假设我们的项目用的是Ant Design Pro 5.0版本,要求React17.0.2版本。(npm5及以上版本,--save是默认行为,不需要显式添加)
bash 复制代码
npm install react@17.0.2 react-dom@17.0.2

1.1 我们从package.json里查看版本。

1.2 我们从node_modules中的antd的package.json查看实际我们所安装的版本!


思路2-熟练运用万能的--legacy-peer-deps和--force

  1. 由于项目依赖太旧了,于是解析依赖关系时出现冲突,终端报错!

有两个方法:

2.1 旧版本的依赖项无法与新版本的npm兼容,这就需要我们后缀--legacy-peer-deps。(推荐)

  • --legacy-peer-deps 选项允许npm在处理peer dependencies时采用旧版本的方式,以确保与旧版本的依赖项保持兼容性。
bash 复制代码
npm install react@17.0.2 react-dom@17.0.2 --legacy-peer-deps

2.2 遇事不决后缀--force。

  • --force 选项强制 npm 执行某个操作,即使有潜在的问题或依赖冲突。
  • 使用 --force 可能会导致安装不兼容的依赖,因此谨慎使用。
bash 复制代码
npm install react@17.0.2 react-dom@17.0.2 --force

思路3-刚接手新项目的报错解决方法

  1. 正常情况下我们刚接手到一个新项目,如果npm install报错,有以下常用方法:

3.1 我们直接降node版本就行了!

  • 推荐使用nvm管理node版本,nrm管理npm源!

3.2 通过其他包管理器解决,如cnpm、pnpm、yarn等等。

3.3 或许应该看看自己的npm源~然后切换成最新的淘宝镜像。

bash 复制代码
npm config get registry
相关推荐
咬人喵喵17 小时前
CSS Flexbox:拥有魔法的排版盒子
前端·css
LYFlied17 小时前
TS-Loader 源码解析与自定义 Webpack Loader 开发指南
前端·webpack·node.js·编译·打包
yzp011217 小时前
css收集
前端·css
暴富的Tdy17 小时前
【Webpack 的核心应用场景】
前端·webpack·node.js
遇见很ok17 小时前
Web Worker
前端·javascript·vue.js
风舞红枫17 小时前
前端可配置权限规则案例
前端
zhougl99617 小时前
前端模块化
前端
xiliuhu17 小时前
Node.js 的事件循环机制
node.js
暴富暴富暴富啦啦啦17 小时前
Map 缓存和拿取
前端·javascript·缓存
天问一17 小时前
前端Vue使用js-audio-plugin实现录音功能
前端·javascript·vue.js