当前位置: 首页 > article >正文

【React bug解决】React 创建项目以及相关问题解决

一、问题背景

最近想要去做一下React的项目实战,因此使用脚手架创建一个项目,从而遇到了一些问题。这里记录了一下所遇到问题以及解决的问题。
使用react脚手架创建react项目的代码

create-react-app 项目名 —template [template-name]

//两个例子
//单纯的创建一个react app
create-react-app my_app
//创建一个使用ts语言的项目
create-react-app my_app —template typescript

二、遇到的问题以及相关解决方案。

2.1 下载速度慢的问题

换下载源。

//npm设置下载源
npm config set registry https://registry.npmmirror.com/ 
//查看当前下载源
npm config get registry

上述是npm配置的语法

npm config set [-g|—global] key value #设置全局配置,或者局部配置(没有-g)
npm [config] get key   //[]是指可以不写

2.2 遇到的问题,dependency下载时冲突问题

在这里插入图片描述
问题发生原因:这里是peer dependency与常规dependency发生冲突所发生的问题,在npm7之前,不会直接下载peer dependency,npm7之后,设置了下载peer dependency,产生了这个问题。

peer dependency与dependency之间的区别:
网上看见的概念:与常规依赖(dependency)不同,Peer dependency 主要用于确保多个模块在同一个主模块的上下文中使用,并共享依赖的版本,这个概念的理解对于构建可维护、稳定和可扩展的Node.js应用程序和包非常重要。
当一个包依赖于另一个包的时候会有一个最低要求的版本号,这个是dependency;
而另一个包可能需要使用更高等级的依赖包,为了兼容整个项目的版本号的依赖包是peer dependency。
Peer dependency 要求依赖包使用相同版本的库。
下面是我对上述概念的理解:
在这里插入图片描述
因此,当dependency已经下载了一个版本的依赖包后,peer dependency再次下载这个依赖包的另一个版本号后会报错说发生冲突。(我的理解这个问题发生的原因)
因此,在下载的时候设置强制下载。

npm install 包名 —force     //直接覆盖

忽略依赖冲突问题继续下载,就是忽略相同模块但不同版本的问题:

npm install 包名 —legacy-peer-deps    //不覆盖跳过

配置下载的时候

npm config set legacy-peer-deps true

这种情况发生在package.json文件中没有显示依赖核心库,如果显示依赖了,子项目中的peer dependency就会忽略。

2.3 缺少包

Cannot find module 'ajv/dist/compile/codegen'

缺少ajv这个包,下载的时候需要看依赖核心库的版本下载。需要安装ajv和ajv-errors两个包。


http://www.kler.cn/a/487673.html

相关文章:

  • vue,router路由传值问题,引用官方推荐
  • HTML5 加载动画(Loading Animation)
  • 直流无刷电机控制(FOC):电流模式
  • MATLAB算法实战应用案例精讲-【数模应用】图像边缘检测(附MATLAB和python代码实现)(二)
  • Rust:运行调用 Lua 脚本
  • 【计算机网络】IPSec的安全协议和封装模式
  • EDA数据分析结合深度学习---基于EDA数据分析和MLP模型的天气预测(tensorflow实现)
  • Linux一键安装Docker和Docker Compose
  • apollo内置eureka dashboard授权登录
  • C语言中的变量与常量
  • 【学Rust开发CAD】2 创建第一个工作空间、项目及库
  • 代码随想录 哈希 test 8
  • Oracle Dataguard(主库为双节点集群)配置详解(2):备库安装 Oracle 软件
  • Android14上使用libgpiod[gpioinfo gpioget gpioset ...]
  • Word快捷键汇总
  • 《软硬协同优化,解锁鸿蒙系统AI应用性能新高度》
  • 《通过财报看企业》
  • springmvc搭建流程
  • ClickHouse 教程
  • # 网络编程 - 轻松入门不含糊