react15升级17问题记录

,当前旧项目主要依赖版本介绍:这里只贴出重要依赖包的旧版本做展示,可以看到版本都相当落后了,升级的话会涉及一些API以及依赖的修改或者弃用
次文章只记录当前项目使用,其他项目不一定通用

{"react": "^15.6.1","react-dom": "^15.6.1","react-draft-wysiwyg": "^1.10.0","react-redux": "^5.0.5","react-router": "^4.1.1","react-router-dom": "^4.1.1","redux": "^3.6.0","redux-actions": "^2.0.3","react-dev-utils": "^3.1.0","react-error-overlay": "^1.0.10","babel": "^6.23.0","babel-cli": "^6.24.1","babel-core": "6.25.0","babel-eslint": "7.2.3","babel-jest": "^20.0.3","babel-loader": "7.1.1","babel-plugin-import": "^1.1.1","babel-plugin-transform-decorators-legacy": "^1.3.4","babel-preset-es2015": "^6.24.1","babel-preset-react": "^6.24.1","babel-preset-react-app": "^3.0.2","babel-preset-stage-2": "^6.24.1","babel-runtime": "^6.23.0","css-loader": "0.28.4","file-loader": "0.11.2","postcss-flexbugs-fixes": "3.2.0","postcss-loader": "2.0.6","style-loader": "0.18.2","url-loader": "0.5.9","eslint": "4.4.1","eslint-config-react-app": "^2.0.0","eslint-loader": "1.9.0","eslint-plugin-flowtype": "2.35.0","eslint-plugin-import": "2.7.0","eslint-plugin-jsx-a11y": "5.1.1","eslint-plugin-react": "7.1.0","webpack": "3.5.1","webpack-dev-server": "2.7.1","webpack-manifest-plugin": "1.2.1","html-webpack-plugin": "2.29.0","sw-precache-webpack-plugin": "0.11.4",
}

升级之后版本:升级之后还多出来了一些依赖包,替换了一些依赖包,比如:mini-css-extract-plugin

{"react": "^17.0.2","react-dom": "^17.0.2","react-redux": "^7.2.9","react-router": "^5.3.4","react-router-dom": "^5.3.4","redux": "^4.2.1","redux-actions": "^2.6.5","react-dev-utils": "^6.1.1","react-error-overlay": "^1.0.10","@babel/cli": "^7.24.1","@babel/core": "^7.0.0","@babel/plugin-proposal-class-properties": "^7.0.0","@babel/plugin-proposal-decorators": "^7.0.0","@babel/plugin-proposal-export-namespace-from": "^7.0.0","@babel/plugin-proposal-function-sent": "^7.0.0","@babel/plugin-proposal-json-strings": "^7.0.0","@babel/plugin-proposal-numeric-separator": "^7.0.0","@babel/plugin-proposal-private-property-in-object": "^7.21.11","@babel/plugin-proposal-throw-expressions": "^7.0.0","@babel/plugin-syntax-dynamic-import": "^7.0.0","@babel/plugin-syntax-import-meta": "^7.0.0","@babel/preset-env": "^7.0.0","@babel/preset-react": "^7.0.0","@babel/runtime-corejs2": "^7.0.0","babel-core": "^7.0.0-bridge.0","babel-eslint": "^10.1.0","babel-jest": "^23.4.2","babel-loader": "^8.0.0","babel-plugin-import": "^1.1.1","babel-preset-react-app": "^10.0.1","css-loader": "^4.3.0","postcss-loader": "^3.0.0","file-loader": "^6.2.0","style-loader": "^2.0.0","url-loader": "^4.1.1","eslint": "^6.8.0","eslint-config-react-app": "^5.2.1","eslint-loader": "^4.0.2","eslint-plugin-flowtype": "^4.7.0","eslint-plugin-import": "^2.29.1","eslint-plugin-jsx-a11y": "^6.8.0","eslint-plugin-react": "^7.34.1","eslint-plugin-react-hooks": "^2.5.1","webpack": "^4.47.0","webpack-cli": "^3.3.12","webpack-dev-server": "^3.11.3","webpack-manifest-plugin": "^4.1.1","sw-precache-webpack-plugin": "^1.0.0","html-webpack-plugin": "^4.5.2","mini-css-extract-plugin": "^1.6.2",
}

升级步骤及遇到的问题:

  1. 安装17版本的react、react-dom (npm i react@17 react-dom@17)
  2. 安装5版本的react-router、react-router-dom
  3. 升级babel:输入命令行npx babel-upgrade --write会自动升级到babel7的版本,这也是为什么会多出来一些babel包的原因
  4. 升级到webpack4版本
  5. 升级eslint相关的插件到最新版本

以上升级先在控制台执行命令改变package.json文件,然后删除node_modules包,删除.lock文件,执行npm的缓存清除命令,然后重新npm install,其中清npm缓存命令如下:
npm cache clean --force
这个命令将会清除npm缓存目录中的所有数据。请注意,–force 参数是必须的,因为从npm v5开始,运行无参数的npm cache clean不再允许删除所有缓存。
npm cache verify
如果你使用的是npm的较新版本(v5及以上),你可以使用这个命令,这个命令会校验并清理无效或损坏的缓存条目。它不会删除所有缓存,但它确实会清理并且优化缓存。

npm i之后,运行项目,会报错,大体分成几类:
一、 Cannot find module…;找不到包
这种解决方法就是:缺什么装什么

二、依赖之间版本不对等问题
解决方法:控制台会提示当前依赖关联的那些依赖需要的版本,对应升级即可
但是会产生很多不太好解决的问题,比如:依赖之间形成依赖闭环,A->B->C->D->A,这种需要先理清楚依赖之间的关系,然后从package.json中手动删除这些依赖,重新逐个升级

三、webpack的编译问题
分成几种:
1. 插件丢弃,这就需要自己逐个查找了,看插件在新版本中是否还在使用(官方文档会有说明)
在开发配置和生产配置中找到对应丢弃的插件进行删除,那之前对应插件的功能就没有了怎么办?不用担心,随着版本的升级,这些丢弃的功能大多已被集成到新版本中了
2. 插件替换,官方同样会说明需要用什么新插件替换,如何使用
3. 插件配置变更:有的插件还在使用但是配置上略作调整

以下是几个典型的问题:

问题:Module build failed: Error: .plugins[1][1] must be an object, false, or undefined
options: {
plugins: [
// “transform-decorators-legacy”,
// [‘import’, [{ libraryName: ‘antd’, style: true }]],
[“@babel/plugin-proposal-decorators”, { “legacy”: true }], // 插件替换
[‘import’, { libraryName: ‘antd’, style: true }], // 插件配置做变更
],
cacheDirectory: true,
},

问题:Plugin could not be registered at ‘html-webpack-plugin-before-html-processing’. Hook was not found.
升级html-webpack-plugin到4 // 插件版本升级

问题:this.htmlWebpackPlugin.getHooks is not a function
插件:new InterpolateHtmlPlugin(HtmlWebpackPlugin, env.raw),// 插件配置做变更

问题:与eslint相关的插件报错
升级与eslint相关的插件匹配webpack4 // 插件版本升级

问题:Error: Failed to load plugin ‘react-hooks’ declared in ‘package.json » eslint-config-react-app’: Cannot find module ‘eslint-plugin-react-hooks’
安装eslint-plugin-react-hooks@2 // 安装缺失插件

问题:页面不报错,也没有任何输出,这个问题是因为之前的配置里面同时使用了html-webpack-plugin和InterpolateHtmlPlugin,前面已经将这两个插件进行结合使用,以为不需要html-webpack-plugin插件了,就将new HtmlWebpackPlugin() 注释掉了,但是就没有输出了
检查html-webpack-plugin的使用

插件去除(生产环境):DefinePlugin、UglifyJsPlugin
插件去除(开发环境):NamedModulesPlugin

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/824274.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Lua语言 备查

开发工具 1.SciTE (入门级) IDEA lua (商业级) 基础 注释 --单行注释 a "hello" --a是一个标识符号--多行注释 --[[这是多行注释]]--连接符 -- .. str 123..456变量 变量类型可以随意改变 数字开头会报错 五种基本…

postman 调试 传base64字符串 原来选xml

上个图 工具类 package org.springblade.common.utils;import com.alibaba.fastjson.JSONObject; import org.springblade.modules.tc.mas.Submit;import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStrea…

【FreeRTOS】使用CubeMX快速移植FreeRTOS工程到蓝桥杯开发板(STM32G431RBT6)

使用CubeMX快速创建FreeRTOS工程到蓝桥杯开发板(STM32G431RBT6) CubeMX配置CubeMX基础工程的配置☆FreeRTOS相关配置FreeRTOS配置选项卡的解释 软件工程架构与程序设计小综合:任务的创建删除、挂起与恢复设计cubexMX配置创建任务软件程序设计…

python怎么连接oracle

一:弄清版本,最重要!!! 首先安装配置时,必须把握一个点,就是版本一致!包括:系统版本,python版本,oracle客户端的版本,cx_Oracle的版本…

基于go+vue的多人在线聊天的im系统

基于govue的多人在线聊天的im系统 文章目录 基于govue的多人在线聊天的im系统一、前端部分二、后端部分1、中间件middleware设计jwt和cors2、配置文件设计3、Mysql和Redis连接4、路由设计5、核心功能设计 一、前端部分 打算优化一下界面,正在开发中。。。 二、后端…

OpenHarmony实战开发-如何使用Navigation实现多设备适配。

介绍 在应用开发时,一个应用需要适配多终端的设备,使用Navigation的mode属性来实现一套代码,多终端适配。 效果图预览 使用说明 将程序运行在折叠屏手机或者平板上观看适配效果。 实现思路 本例涉及的关键特性和实现方案如下&#xff1a…

【WebLogic】Oracle发布2024年第二季度中间件安全公告

Oracle于美国时间2024年4月16日发布了 WebLogic 中间件2024年第二季度的安全公告,涉及漏洞共计 10 个,涉及示例程序的高危漏洞 1 个,中危漏洞中有3个涉及到核心组件(Core)。 此外,Oracle JDK1.8 的小版本号…

整理Meta GDC 2024 上关于XR、空间计算相关的分享

Meta 在 GDC 2024 上的全面覆盖,涵盖了如何利用 Meta Quest 构建全息游戏以及如何利用平台为开发者创造成功的会议。 视频分为 11 个部分,每个部分都是一场独特的会议,涵盖了从构建下一代 XR 体验到如何利用 Meta Quest 建立业务等话题 比如: 1、利用 Meta Quest 构建全息…

二分法在有序数组中的应用(JavaC)

文章目录 在有序数组中确定num是否存在Java实现C语言实现 在有序数组中找>num的最左位置Java实现C语言实现 在有序数组中找<num的最右位置Java实现C语言实现 在有序数组中确定num是否存在 Java实现 public static boolean exist(int[] arr, int num) {if (arr null ||…

IAttachService

目录 1、 IAttachService 1.1、 * 分页查询附件 1.2、 * 保存附件 2、 ILogService 2.1、 * 保存操作日志 2.2、 * 获取日志分页

【C++题解】1345. 玫瑰花圃

问题&#xff1a;1345. 玫瑰花圃 类型&#xff1a;基本运算、小数运算 题目描述&#xff1a; 有一块nn&#xff08;n≥5&#xff0c;且 n 是奇数&#xff09;的红玫瑰花圃&#xff0c;由 nn 个小正方形花圃组成&#xff0c;现要求在花圃中最中间的一行、最中间的一列以及 4 个…

每天一个数据分析题(二百七十七)

检索销量表中销量最好的商品id和销量&#xff0c;下列SQL语句正确的是&#xff08;&#xff09; A. SELECT 商品id,销量 FROM 销量表 WHERE 销量MAX(销量) B. SELECT 商品id,MAX(销量) FROM 销量表 GROUP BY 销量 C. SELECT 商品id,MAX(销量) FROM 销量表 GROUP BY 商品id …

设计模式学习笔记 - 设计模式与范式 -总结:2.实际开发中如何避免过度设计,如何避免设计不足?

概述 设计模式的理论部分已经学完了。我想你一定蠢蠢欲动&#xff0c;想要赶紧实践一下&#xff0c;把这些理论知识应用到自己的项目中。不过&#xff0c;要注意下面两点&#xff1a; 一种是过度设计。在开始编写代码之前&#xff0c;花很长的时间做代码设计&#xff0c;在开…

聊聊linux的文件缓存

序 本文主要研究一下linux的文件缓存 文件缓存 linux使用page cache来缓存最近读取的文件&#xff0c;也有目录结构(dcache: Directory Entry Cache)缓存及inode缓存&#xff0c;它们都使用了LRU算法来管理这些page及dentries cache vmstat ## vmstat procs -----------me…

智享ai自动直播系统,直播界的流量增长点。

智享ai自动直播系统&#xff0c;直播界的流量增长点&#xff01; 在当今互联网时代&#xff0c;商家面临着日益激烈的竞争&#xff0c;因为一切内容如价格都变得透明&#xff0c;商家们纷纷寻求新的增长点来获取流量。在线下资源饱和的情况下&#xff0c;线上短视频平台成为商…

Acrobat Pro DC2024安装包(亲测可用)

目录 一、软件简介 二、软件下载 一、软件简介 Acrobat软件是由Adobe公司开发的一款专业的PDF&#xff08;Portable Document Format&#xff0c;便携式文档格式&#xff09;编辑和管理软件。它为用户提供了丰富的功能&#xff0c;涵盖了创建、编辑、转换和共享PDF文件、签名和…

从选品策划、变现、数据分析、App矩阵多方面,分享App蓝海精细化运营玩法

本篇分享主要分为以下两部分: 通过七麦和蝉大师等数据工具或者同行网站选出蓝海产品; 通过版本、语言、皮肤等实现 App 矩阵,获得更多用户并进行差异化变现。 文章目录 —前言—选品标准一个小案例更进阶的选品思路流量变现App 矩阵最后总结—前言— 据官方统计,App St…

使用嘉立创EDA打开JSON格式的PCB及原理图

一、将PCB和原理图放同一文件夹 并打包成.zip文件 二、打开嘉立创EDA并导入.zip文件 文件 -> 导入 -> 嘉立创EDA标准版/专业版 三、选择.zip文件并选择 “导入文件并提取库” 四、自定义工程路径 完成导入并转换为.eprj文件 五、视频教学 bilibili_使用立创EDA打开JSO…

工业自动化,3D视觉技术3C薄片自动化上料

随着制造业的快速发展&#xff0c;3C行业对薄片类零件的上料需求日益增长。传统的上料方式往往依赖于人工操作&#xff0c;效率低下且存在误差。为了解决这一问题&#xff0c;3D视觉技术应运而生&#xff0c;为3C薄片自动化上料提供了强大的技术支持。本文将探讨3D视觉技术如何…

go语言net包里面的PostForm

net包里面的http包里定义了Request结构体&#xff0c;用于http的请求&#xff0c; type Request type Request struct { // Method指定HTTP方法&#xff08;GET、POST、PUT等&#xff09;。对客户端&#xff0c;““代表GET。 Method string // URL在服务端表示被请求的URI&…