轻松搞定-react-6-路由-1-配置-懒加载

简介: 轻松搞定-react-6-路由-1-配置-懒加载

1. 前言

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

2. 效果演示

  1. 效果图image.png
    设计图.png
  2. 下述逻辑按这个来实现

3. 相关依赖安装

  1. 路由默认最新6.X, 如需使用5.x, 在模块名后加@5

npm install react-router-dom  @loadable/component  --save     // 6.0
    npm install react-router-dom@5 --save   // 5.0
     //开发依赖
    npm install  sass -D
  1. sass 属于开发依赖
  2. @loadable/component 路由懒加载
  3. 贴下主要依赖版本

//生产依赖
    "react": "^18.2.0",
    "react-dom": "^18.2.0",
    "react-router-dom": "^6.3.0",
   "@loadable/component": "^5.15.2",
// 开发依赖
    "sass": "^1.52.3"
  }

4. 应用场景

  1. SPA单页应用,因为单页应用只有一个index.html,我们所看到的的跳转其实都是假跳,而React不自带这个功能,所以使用react-router-dom,vue中的vue-router也是一样的道理
  2. 创建项目

create-react-app 项目名/play-router6

5.  页面准备

  1. 路由嘛 需要跳转页面,所以先创建4个页面
  2. src/pages/home/index.jsx
  3. src/pages/friendList/index.jsx
  4. src/pages/friendCircle/index.jsx
  5. src/pages/my/index.jsx
  6. rfc 是函数式组件快捷方式
  7. rcc 是类组件快捷方式 插件是 ES7+ React/Redux/React-Native snippets
  8. 每个页面写个h1标签 简单标识下页面 用于显示区分

import React, { Component } from 'react'
export default class index extends Component {
  render() {
    return (
      <div>
        <h1>主页</h1>
      </div>
    )
  }
}

6. 路由配置

6.1 完整配置

  1. 我个人习惯单独搞个路由配置文件,有些人习惯直接写在入口index.js里面,自己开心就好
  2. 目录结构 src/rouer/index.jsx
  3. 先上代码在分析

import loadable from "@loadable/component";
import Loading from "../components/Loading";
import Home from "../pages/home";
import { Routes, Route } from "react-router-dom";
const  FriendList = loadable(()=>import("../pages/friendList"),{ fallback: <Loading /> }) ;
const  FriendCircle = loadable(()=>import("../pages/friendCircle"),{ fallback: <Loading /> }) ;
const  MyPage = loadable(()=>import("../pages/my"),{ fallback: <Loading /> }) ;
export default function () {
  return (
    <Routes>
      <Route path="/" element={<Home />} />
      <Route path="/fl" element={<FriendList />} />
      <Route path="/fc" element={<FriendCircle />} />
      <Route path="/my" element={<MyPage />} />
    </Routes>
  );
}

6.2 懒加载的用法

  1. @loadable/component路由懒加载的使用

import loadable from "@loadable/component";
import Loading from "../components/Loading";
loadable(()=>import("../pages/friendList"),{ fallback: <Loading /> })
  1. 其实这个import的写法和vue-router懒加载一样
  2. 第二个参数是 加载回调加载动画,可以自己设置组件
  3. Loading组件 image.png
    Loading组件.png

6.3 Route

  1. Route 用来定义一个访问路径与 React 组件之间的关系
  2. 对比vue-router就是单个路由配置
  3. path必须的属性  url显示的路径
  4. element用来显示组件  注意 组件必须是标签,不能直接写组件名,必须是<组件名>格式
  5. 懒省事也可以这样写 element={<div>我是主页</div>}

6.4 Routes

  1. Routes 是用来包住路由访问路径(Route)的。它决定用户在浏览器中输入的路径到对应加载什么 React 组件
  2. 绝大多数情况下,Routes 的唯一作用是用来包住一系列的 Route ;
  3. 对比vue-router就是 路由配置表

7. 入口  index.js配置

  1. 直接上代码 这是react 18.X
  2. as别名 看个人习惯

import { BrowserRouter as Router } from "react-router-dom";
import RouterComponent from "./router";
const root = ReactDOM.createRoot(document.getElementById("root"));
root.render(
  <Router>
    <React.StrictMode>
      <App />
    </React.StrictMode>
    <RouterComponent />
  </Router>
);
  1. 使用BrowserRouter把整个应用程序的入口包裹,就相当于把路由模块包功能挂载到应用程序实例。
    4.BrowserRouter就是其中的一个路由组件,就是其中的一个路由模式。浏览器端路由模式
  2. HashRouter路由组件是另外一个路由模式。Hash路由模式
  3. MemoryRouter路由组件是另外一个路由模式。缓存路由模式

8. App.jsx

  1. 为了方便把 App.js改为了 App.jsx
  2. App.css改为了 App.scss
  3. 也可以直接在 入口index.js配置,看个人习惯
  4. 直接上代码 在分析

import "./App.scss";
import { NavLink } from "react-router-dom";
function App() {
  return (
    <div className="App">
      <div className="NavBar">
        <NavLink to="/" activeclassname="active">主页</NavLink>
        <NavLink to="/fl">联系人</NavLink>
        <NavLink to="/fc">朋友圈</NavLink>
        <NavLink to="/my">我的</NavLink>
      </div>
    </div>
  );
}
export default App;
  1. 清空了原来的内容,自己写
  2. activeclassname 路由自带的选中样式
  3. 样式,我把导航放到了底部

.NavBar  {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  background-color: #2567ff;
  height: 50px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  a{
    flex: 1;
    text-decoration: none;
    color: #FFF;
  }
  .active{
    color: #F00;
  }
}

9. 后记

  1. 就到这,是个基础配置,也有界面效果
  2. 下篇文章嵌套路由-404

参考资料

6.x 嵌套路由-404配置-2

6x 路由传值

react-router-dom 官网


初心

我所有的文章都只是基于入门,初步的了解;是自己的知识体系梳理,如有错误,道友们一起沟通交流;
如果能帮助到有缘人,非常的荣幸,一切为了部落的崛起;
共勉
相关文章
|
3月前
|
前端开发 JavaScript
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
本文介绍了在React项目中实现路由懒加载的方法,使用React提供的`lazy`和`Suspense`来优化项目首次加载的速度。通过将路由组件改为懒加载的方式,可以显著减少初始包的大小,从而加快首次加载速度。文章还展示了如何使用`Suspense`组件包裹`Switch`来实现懒加载过程中的fallback效果,并提供了使用前后的加载时间对比,说明了懒加载对性能的提升作用。
212 2
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
|
23天前
|
前端开发 API UED
React 懒加载图片 Lazy Image
懒加载是一种优化技术,通过延迟加载不在视口内的图片,减少初始页面加载时间,提升用户体验。本文从基础概念入手,逐步探讨 React 中实现图片懒加载的常见问题、易错点及解决方案,并通过代码案例详细解释。
29 3
|
1月前
|
前端开发 API UED
React 路由守卫 Guarded Routes
【10月更文挑战第26天】本文介绍了 React 中的路由守卫(Guarded Routes),使用 `react-router-dom` 实现权限验证、登录验证和数据预加载等场景。通过创建 `AuthContext` 管理认证状态,实现 `PrivateRoute` 组件进行路由保护,并在 `App.js` 中使用。文章还讨论了常见问题和易错点,提供了处理异步操作的示例,帮助开发者提升应用的安全性和用户体验。
48 1
|
1月前
|
前端开发 安全 网络安全
React——路由Route
React——路由Route
34 2
React——路由Route
|
2月前
|
资源调度 前端开发 测试技术
React Router 路由管理
【10月更文挑战第10天】本文介绍了 React Router,一个在 React 应用中管理路由的强大工具。内容涵盖基本概念、安装与使用方法、常见问题及解决方案,如路由嵌套、动态路由和路由守卫等,并提供代码示例。通过学习本文,开发者可以更高效地使用 React Router,提升应用的导航体验和安全性。
286 19
|
2月前
|
缓存 前端开发 UED
React Suspense 懒加载详解
【10月更文挑战第18天】React Suspense 是 React 16.6 引入的新特性,主要用于处理异步数据获取和组件懒加载。本文从 Suspense 的基本概念出发,介绍了其在代码分割和数据获取中的应用,通过具体代码示例展示了如何使用 `React.lazy` 和 `Suspense` 实现组件的懒加载,并探讨了实践中常见的问题及解决方法,帮助开发者提升应用性能和用户体验。
85 1
|
2月前
|
前端开发 网络架构
React 路由
10月更文挑战第11天
34 2
|
2月前
|
前端开发 JavaScript 网络架构
实现动态路由与状态管理的SPA——使用React Router与Redux
【10月更文挑战第1天】实现动态路由与状态管理的SPA——使用React Router与Redux
39 1
|
3月前
|
前端开发 Python
React技术栈-React路由插件之自定义组件标签
关于React技术栈中React路由插件自定义组件标签的教程。
59 4
React技术栈-React路由插件之自定义组件标签
|
3月前
|
前端开发
react配置proxy代理的两种方式
本文介绍了在React项目中配置代理的两种方式:通过在package.json中添加代理配置,以及通过创建setupProxy.js文件来实现更复杂的代理规则。
128 2