react-6-路由-2-嵌套路由-404

简介: react-6-路由-2-嵌套路由-404

1. 前言

  1. 以前的文章路由都是5x路由配置,最近写个6x的,写完准备玩玩C,到时候在交流
  2. 因为现在脚手架默认安装的react也是18.x了 所以也注意哦
  3. 路由hook用法单独在写文章
  4. react-router-dom 官网 英文的 有兴趣的可以自己看着学
  5. 接着 react-6路由-1-基础

2. 效果演示

  1. 效果图image.png
    演示.gif
  2. 下述逻辑按这个来实现

3. 二级路由配置

  1. 把上节课的朋友里边 修改为二级路由
  2. 先上代码在分析

const  HightSchool = loadable(()=>import("../pages/hightSchool"),{ fallback: <Loading /> }) ;
export default function () {
  return (
    <Routes>
      <Route path="/" element={<Home />} />
      <Route path="/fl" element={<FriendList />} >
        <Route path="" element={ <h3>假装这里是初中同学 列表</h3>}/>
        <Route path="high" element={<HightSchool />}/>
        <Route path="university" element={ <div>假装这里是大学同学 列表</div>}/>
      </Route>
      <Route path="/fc" element={<FriendCircle />} />
      <Route path="/my" element={<MyPage />} />
    </Routes>
  );
}
  1. 嵌套路由的大体逻辑就是 Route嵌套Route,vue-router也差不多,子路由配置都一样
  2. 子路由 path为空 就会默认显示这个子路由,和编写的顺序没有关系,放在最后一个也是默认显示

4.  跳转路由

  1. 子路由的出口在父路由,所以代码写到friendList里面
  2. NavLink相当于vue的router-link
  3. Outlet 是 子路由的出口组件哦

import { NavLink, Outlet } from "react-router-dom";
export default function index() {
  return (
    <div>
      <h1>联系人</h1>
      {/* 第一个/不能省不然会默认 拼接  */}
      <NavLink to="/fl/"> 初中同学</NavLink>
      <NavLink to="/fl/high"> 高中学同学</NavLink>
      <NavLink to="/fl/university"> 大学同学</NavLink>
      {/*  二级路由显示的容器,Outlet出口 */}
      <Outlet />
    </div>
  );
}
  1. 简单效果图image.png
    1.png
  2. 单独把这个 高中作为组件来实现了

export default function () {
  return (
    <div>
        <h1>假装这里是高中同学列表</h1>
    </div>
  )
}

5.  三级路由

  1. 以朋友列表高中同学为例,写3级路由
  2. 路由配置

<Route path="/fl" element={<FriendList />} >
        <Route path="" element={ <h3>假装这里是初中同学 列表</h3>}/>
        <Route path="university" element={ <div>假装这里是大学同学 列表</div>}/>
        <Route path="high" element={<HightSchool />}>
            <Route path="two" element={<h3> 假装这里是 高二同学 界面</h3>}/>
            <Route path="" element={<div> 假装这里是 高一同学 界面</div>}/>
        </Route>
      </Route>

6. 页面使用配置

  1. 注意出口

import { NavLink, Outlet } from "react-router-dom";
export default function () {
  return (
    <div>
        <h1>假装这里是高中同学列表</h1>
        <NavLink to="/fl/high/"> 高1同学</NavLink>
        <NavLink to="/fl/high/two"> 高2学同学</NavLink>
        <Outlet/>
    </div>
  )
}
  1. 效果图image.png
    三级路由.png

7. 404 配置

  1. so  easy

// 用来作为 404 页面的组件
const NotFound = () => {
  return <div>一朝一夕日复日,半醉半醒浮生梦</div>
}
export default function () {
  return (
    <Routes>
       // 放到末尾就行
      <Route path="*" element={<NotFound />} />
    </Routes>
  );
}
  1. 简单演示image.png
    演示404.png

8. 后记

  1. 就到这,是个基础配置,也有界面效果
  2. hook

参考资料

6.x 路由基础 -1

6.x 路由传值

react-router-dom 官网


初心

我所有的文章都只是基于入门,初步的了解;是自己的知识体系梳理,如有错误,道友们一起沟通交流;
如果能帮助到有缘人,非常的荣幸,一切为了部落的崛起;
共勉
相关文章
|
2月前
|
前端开发 JavaScript
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
本文介绍了在React项目中实现路由懒加载的方法,使用React提供的`lazy`和`Suspense`来优化项目首次加载的速度。通过将路由组件改为懒加载的方式,可以显著减少初始包的大小,从而加快首次加载速度。文章还展示了如何使用`Suspense`组件包裹`Switch`来实现懒加载过程中的fallback效果,并提供了使用前后的加载时间对比,说明了懒加载对性能的提升作用。
176 2
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
|
15天前
|
前端开发 API UED
React 路由守卫 Guarded Routes
【10月更文挑战第26天】本文介绍了 React 中的路由守卫(Guarded Routes),使用 `react-router-dom` 实现权限验证、登录验证和数据预加载等场景。通过创建 `AuthContext` 管理认证状态,实现 `PrivateRoute` 组件进行路由保护,并在 `App.js` 中使用。文章还讨论了常见问题和易错点,提供了处理异步操作的示例,帮助开发者提升应用的安全性和用户体验。
30 1
|
3月前
|
移动开发 资源调度 前端开发
介绍React路由模式
【8月更文挑战第10天】介绍React路由模式
57 12
|
18天前
|
前端开发 安全 网络安全
React——路由Route
React——路由Route
27 2
React——路由Route
|
1月前
|
资源调度 前端开发 测试技术
React Router 路由管理
【10月更文挑战第10天】本文介绍了 React Router,一个在 React 应用中管理路由的强大工具。内容涵盖基本概念、安装与使用方法、常见问题及解决方案,如路由嵌套、动态路由和路由守卫等,并提供代码示例。通过学习本文,开发者可以更高效地使用 React Router,提升应用的导航体验和安全性。
199 19
|
1月前
|
前端开发 网络架构
React 路由
10月更文挑战第11天
33 2
|
1月前
|
前端开发 JavaScript 网络架构
实现动态路由与状态管理的SPA——使用React Router与Redux
【10月更文挑战第1天】实现动态路由与状态管理的SPA——使用React Router与Redux
32 1
|
2月前
|
前端开发 Python
React技术栈-React路由插件之自定义组件标签
关于React技术栈中React路由插件自定义组件标签的教程。
54 4
React技术栈-React路由插件之自定义组件标签
|
2月前
|
移动开发 前端开发 应用服务中间件
React两种路由模式的实现原理
React两种路由模式的实现原理
83 3
|
2月前
|
前端开发 程序员 API
React技术栈-React路由插件之react-router的基本使用
这篇博客介绍了React路由插件react-router的基本使用,包括其概念、API、以及如何通过实战案例在React应用中实现SPA(单页Web应用)的路由管理。
68 9