React之动态路由创建以及解决刷新白屏问题

news2024/10/6 18:36:28

动态路由的创建和动态菜单的创建几乎类似,只不过的是,动态路由需要导入组件。这样才能完成跳转。

动态路由与动态菜单一样都需要封装一个转化函数,将后端传来的数据进行转换,转换成我们需要的格式。

需要导入的依赖

导入路由useRoutes

import {useRoutes} from 'react-router-dom'

导入useEffect, useState进行异步请求和保存路由表

import { useEffect, useState } from 'react'

导入axios

import $api from './request/index'

导入高阶组件进行二级路由的渲染

import withLoadable from './hoc/withLoadable'

导入鉴权组件

import Auth from './components/Auth'

导入登录和首页的组件,因为路由表中的一级路由是登录和首页

const Login = withLoadable(()=>import('./views/Login/Login'))

const Home = withLoadable(()=>import('./views/homePage/Home.jsx'))

在App组件中我们需要返回的是路由表,所以将配置好后的路由表传给useRoutes,

useRoutes中路由表有三个属性:path,element,children

转化函数依旧是使用的是递归来进行动态获取多级路由

1️⃣:首先调用获取路由的接口,并且将获取的数据传送到转换函数中

 const getMenus = async()=>{
    let result = await $api.login.getMenus()
   let RoutesAry =  transformRouter(result.data)
      routes[1].children = RoutesAry
      // 这里可以解决页面按F5出现白屏,需要深拷贝
      setRoutes([...routes])
  }

2️⃣:编写转换函数

 const transformRouter = (RouterList)=>{
    function transform(RouterList){
        if(RouterList && RouterList.length >0){
          RouterList.forEach(item=>{
            if(item.childList&&item.childList.length>0){
              item.childList.forEach(subItem=>{
                const Module = withLoadable(()=>import(`./views${subItem.component}`))
                let routeItem={
                  path:subItem.component,
                  element:<Module></Module>
                }
                RoutesAry.push(routeItem)
                transform(item.childList,RoutesAry)
              })
            }else{
              const Module = withLoadable(()=>import(`./views${item.component}`))
                let routeItem={
                  path:item.component,
                  element:<Module></Module>
                }
                RoutesAry.push(routeItem)
            }
          })
        }
    }
    let RoutesAry = []
    transform(RouterList,RoutesAry)
      return RoutesAry
  }

转化函数的步骤:

- 首先对传进来的RouterList进行遍历,因为我们跳转是从二级路由开始跳转的,所以我们要对传进来的数据进行forEach遍历取里面的二级路由数据。

- 再取得二级路由以后我们需要对二级路由进行判断,如果childList有并且长度需大于0

- childList判断完之后,对childList进行遍历

- 使用高阶组件withLoadable,将二级菜单的组件传输到高阶组件之中。

const Module = withLoadable(()=>import(`./views${subItem.component}`)

- 因为路由表是一个数组包对象的结构,对象里面包括path属性和element属性。所以定一个routeItem对象,将Module组件和subItem.component给对象里的属性进行赋值。

对象创建好后,将routeItem添加到RoutesAry数组中。

注意:这里需要注意的是,如果不递归的话,他只能进行到二级路由,只有递归了,多级路由才能被添加进去。

- 当一级路由没有二级路有的话,我们直接将一级路由添加到RoutesAry数组中。

- 数组转化完成后,将转化好后的数据赋值给一个新数组RoutesAry,并且将这个数组赋值给路由表中一级路由home组件的children属性。


   let RoutesAry =  transformRouter(result.data)
   console.log(result.data);
      routes[1].children = RoutesAry
      // 这里可以解决页面按F5出现白屏,需要深拷贝
      setRoutes([...routes])

注意:我们把路由表配置好后,都要统一用useState保存路由表,然后将路由表传给useRoutes函数

 return useRoutes(routes)

解决首次进入路由白屏的问题:

当我们登录成功后,进入主页面进行路由跳转时我们发现此时页面发生白屏现象。这是因为useState只在组件初次加载的时候进行调用,所以会出现白屏现象,我们只需要将路由表进行一个深拷贝传入setRoutes函数中就可以解决白屏。

 const [routes,setRoutes] = useState([
    {
      path:'/login',
      element:<Login></Login>
    },
    {
      path:'/',
      element:<Auth><Home></Home></Auth>
    }
  ])
  const getMenus = async()=>{
    let result = await $api.login.getMenus()
   let RoutesAry =  transformRouter(result.data)
   console.log(result.data);
      routes[1].children = RoutesAry
      // 这里可以解决页面按F5出现白屏,需要深拷贝
      setRoutes([...routes])
  }

完整的代码:

 

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

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

相关文章

kali: kali工具-Ettercap

kali工具-Ettercap ettercap工具&#xff1a; 用来进行arp欺骗&#xff0c;可以进行ARP poisoning&#xff08;arp投毒&#xff09;&#xff0c;除此之外还可以其他功能&#xff1a; ettercap工具的arp投毒可以截取web服务器、FTP服务器账号密码等信息&#xff0c;简略后打印出…

C++篇--类大小计算、this指针

文章目录 一、类大小计算二、this指针 一、类大小计算 类的大小是只计算它的成员变量或者自定义成员&#xff0c;不会计算它的成员函数大小。 #include<iostream> using namespace std;class A1 { public:void fun(){_a 1;_b 2;}int _a;int _b; };int main() {cout <…

干货 | 赵亚雄:大模型、AI经济和AI基础设施

大家好&#xff0c;我是算想未来的创始人CEO赵亚雄。今天非常高兴到母校来做简短的分享。我们最近会几乎是被ChatGPT、OpenAI等等话题各类的信息轮番轰炸。我希望借助这个机会&#xff0c;把自己这一段时间来思考的有关AI基础设施还有AGI再到大模型等内容&#xff0c;从相对抽象…

ElasticSearch创建文档以及索引文档的详细流程

当我们发起一个查询请求之后&#xff0c;ES是怎么处理这个请求然后返回数据的呢&#xff1f;今天就来详细说一下。 首先看一下整体结构&#xff1a; 在集群模式下一个索引有多个分片&#xff0c;在上图中有三个节点(一个主节点两个从节点)&#xff0c;一个索引被分为两个分片(…

基于协同过滤的旅游推荐系统设计与实现(论文+源码)_kaic

1 绪论 1.1 研究背景及意义 1.2 国内外研究现状 1.3 研究目标与意义 1.4 主要研究工作 2 相关理论介绍 2.1HTML与JavaScript 2.2 MySQL数据库 2.3 协同过滤算法简介 3 系统分析与设计 3.1 系统需求分析 3.1.1 功能性需求 3.1.2 安全性需求 3.2 系统总体架构 3.3 功能模块设计 3…

vue3的props和defineProps

文章目录 1. Props 声明1.1 props用字符串数组来声明Blog.vueBlogPost.vue 1.2 props使用对象来声明Blog.vueBlogPost.vue 2. 传递 prop 的细节2.1 Prop 名字格式2.1 静态Prop & 动态 Prop静态prop动态prop示例Blog.vueBlogPost.vue 2.3 传递不同的值类型NumberBooleanArra…

【Java笔试强训 11】

&#x1f389;&#x1f389;&#x1f389;点进来你就是我的人了博主主页&#xff1a;&#x1f648;&#x1f648;&#x1f648;戳一戳,欢迎大佬指点! 欢迎志同道合的朋友一起加油喔&#x1f93a;&#x1f93a;&#x1f93a; 目录 一、选择题 二、编程题 &#x1f525;最近公共…

算法记录 | Day46 动态规划

139.单词拆分 思路&#xff1a; 1.确定dp数组以及下标的含义 dp[i] : 字符串长度为i的话&#xff0c;dp[i]为true&#xff0c;表示可以拆分为一个或多个在字典中出现的单词。 2.确定递推公式 如果 s[0: j] 可以拆分为单词&#xff08;即 dp[j] True&#xff09;&#xff…

Linux RHCE解题方法

目录 安装和配置Ansible 创建和运行Ansible临时命令 安装软件包 使用RHEL系统角色 使用 Ansible Galaxy 安装角色 创建和使用角色 从 Ansible Galaxy 使用角色 创建和使用逻辑卷 生成主机文件 修改文件内容 创建 Web 内容目录 生成硬件报告 创建密码库 创建用户帐…

C++中stringstream类详解

本文主要介绍 C 编程语言中 stringstream 类的相关知识&#xff0c;同时通过示例代码介绍 stringstream 类的使用方法。 1 概述 <sstream> 定义了三个类&#xff1a;istringstream、ostringstream 和 stringstream&#xff0c;分别用来进行流的输入、输出和输入输出操作…

快速傅里叶变换FFT学习笔记

点值表示法 我们正常表示一个多项式的方式&#xff0c;形如 A ( x ) a 0 a 1 x a 2 x 2 . . . a n x n A(x)a_0a_1xa_2x^2...a_nx^n A(x)a0​a1​xa2​x2...an​xn&#xff0c;这是正常人容易看懂的&#xff0c;但是&#xff0c;我们还有一种表示法。 我们知道&#xf…

java结束当前循环

在 Java中&#xff0c;当我们要结束一个循环时&#xff0c;通常会使用循环变量的实现类来结束&#xff0c;但在实际开发中&#xff0c;我们经常会遇到某个循环结束后需要进行其他的操作的情况。此时&#xff0c;就需要使用循环变量来结束当前循环。 1、创建一个新的类&#xff…

数据结构_双链表、循环链表、静态链表

目录 1. 双链表 1.1 双链表的初始化 1.2 双链表的插入操作 1.3 双链表的删除操作 1.4 双链表的遍历 2. 循环链表 2.1 循环单链表 2.2 循环双链表 3. 静态链表 4. 顺序表和链表的比较 5. 相关练习 1. 双链表 单链表结点中只有一个指向其后继的指针&#xff0c;使得单…

电子电气架构——车辆E/E架构软硬件解耦

我是穿拖鞋的汉子,魔都中坚持长期主义的工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 人只有在举棋不定,无从把握的时候才感到疲惫。只有去行动就能获得解放,哪怕做的不好也比无所作为强! 本文主要介绍车辆E/E架构常识,主要涉及内容是行业最…

Python实现LBP纹理提取

1、什么是LBP纹理特征&#xff1f; LBP&#xff08;Local Binary Patterns&#xff0c;局部二值模式&#xff09;是提取局部特征作为判别依据的&#xff0c;一种有效的纹理描述算子&#xff0c;度量和提取图像局部的纹理信息。它具有旋转不变性和灰度不变性等显著的优点&#…

uniapp中使用vuex(解决uniapp无法在data和template中获取vuex数据问题)

uniapp中使用vuex&#xff08;解决uniapp无法在data和template中获取vuex数据问题&#xff09; 1. uniapp中引入vuex2. uniapp中使用vuex3. 解决uniapp无法在data和template中获取vuex数据问题 1. uniapp中引入vuex 1 .在根目录下新建文件夹store,在此目录下新建index.js文件&…

第五章——动态规划3

蒙德里安的梦想 我们在黑框内横着放红框&#xff0c;我们发现当横向小方格摆好之后&#xff0c;纵向小方格只能一次纵向摆好&#xff0c;即纵向小方格只有一种方案&#xff0c;即整个摆放小方格的方案数等于横着摆放小方格的方案数 f[i,j]表示的是现在要在第i列摆&#xff0c;j…

代码随想录Day64(一刷完结)

今天学习单调栈解决最后一道题 84.柱状图中的最大矩形 给定 n 个非负整数&#xff0c;用来表示柱状图中各个柱子的高度。每个柱子彼此相邻&#xff0c;且宽度为 1 。 求在该柱状图中&#xff0c;能够勾勒出来的矩形的最大面积。 示例 1: 输入&#xff1a;heights [2,1,5,6,…

C++中的list容器

文章目录 list的介绍list的使用list的构造list iterator的使用list capacitylist元素访问list modifierslist的迭代器失效 list与vector的对比 list的介绍 list是可以在常数范围内的任意位置进行插入和删除的序列式容器&#xff0c;并且该容器可以前后双向迭代&#xff1b;   …

FFMPEG中的filter使用二

上一篇我们在使用滤镜时是手动创建各种滤镜&#xff0c;然后根据处理链路手动链接不同的过滤器&#xff0c;有助于我们理解滤镜的流程。这一篇我们使用参数形式&#xff0c;让ffmpeg自动帮我们创建和链接过滤器&#xff0c;这样可以减少代码量&#xff0c;同时我们可以先使用参…