React中的路由

一、常见的三种路由

(1)页面路由

window.location.href='https://www.hao123.com/'
history.back()

(2)h5路由

window.location = '#hash'
window.onchange = function () {
    console.log(window.location.hash)
}

(3)hash路由

//推进一个状态
history.pushState('name','title','/path')
//替换一个状态
history.replaceState('name','title','/path')

二、React-Router路由介绍

1、路由方式

<BrowserRouter/>  :h5路由

<HashRouter>:hash路由

2、路由规则

<Route/>:包裹组件

3、理由选项

<Switch/>:解决匹配问题,按照顺序匹配,如果匹配到前面的后面的就不匹配了。

例如:/path和、path/list这样的,按照顺序path/list会匹配导/path,达不到想要的效果,加上exact关键词做到完全匹配,必须完全一样才能匹配到。

4、跳转导航,相当于a标签

<Link/>:跳转页面

<NavLink/>:增强版的Link

5、自动跳转

<Redirect/>:不用点击,执行到这块就自动跳转

三、React-Router使用

1、导入包

yarn add react-router-dom

import {BrowserRouter, Route, Link} from "react-router-dom";

2、BrowserRouter包裹

<BrowserRouter>
    <div>
        <Route path={'/'} exact component={Home}></Route>
        <Route path={'/detail/'} component={Detail}></Route>
    </div>
</BrowserRouter>
  • component用来修饰要跳转的路由页面,页面内容为:Home、Detail是两个真实的组件
  • path:匹配的路由规则
  • exact:修饰匹配的效果,加上表示精确匹配,不加表示模糊匹配,例如:
  • path={'/'}表示匹配:http://localhost:3000/,如果是http://localhost:3000/99就无法匹配了
  • path={'/detail/'}表示匹配:http://localhost:3000/detail/xxxxxxx,后面的不限制,前面的的匹配成功就OK了

3、路由的传值

http://localhost:3000/detail

(1)路由参数传值

    路由参数

    <Route path={'/detail/:id'} component={Detail}></Route>

    跳转参数:

    <Link key={index} to={'/detail/' + item.id}>

    接收参数:

    this.props.match.params.id

    打印结果

    3。直接使用

    访问结果

    http://localhost:3000/detail/3

(2)路由参数传值


    路由参数

     <Route path={'/detail'} component={Detail}></Route>

    跳转参数:

    <Link key={index} to={'/detail?=' + item.id}>

    接收参数:

    this.props.location.search

    打印结果

    ?id=3。需要自己解析

    访问结果

    http://localhost:3000/detail?id=3

4、跳转原理

Link的to参数匹配导Route中的path参数,则执行跳转,跳转到Route中的component中设置的组件。

网上摘要的一个图描述的很到位:

 

React 中进行路由配置通常会使用 `react-router-dom` 库,以下是不同场景下的路由配置方法: #### 基本路由配置 ```jsx import { BrowserRouter as Router, Routes, Route } from 'react-router-dom'; import Home from './Home'; import About from './About'; const App = () => { return ( <Router> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> </Routes> </Router> ); }; export default App; ``` 上述代码中,使用 `BrowserRouter` 作为路由容器,`Routes` 组件包裹多个 `Route` 组件,每个 `Route` 组件通过 `path` 属性指定路径,`element` 属性指定该路径对应的组件。 #### 路由重定向 ```jsx import { BrowserRouter as Router, Routes, Route, Redirect } from 'react-router-dom'; import Home from './Home'; const App = () => { return ( <Router> <Routes> <Route path="/home" element={<Home />} /> <Route path="/" element={<Redirect to="/home" />} /> </Routes> </Router> ); }; export default App; ``` 这里使用 `Redirect` 组件实现路由重定向,当访问根路径 `/` 时,会重定向到 `/home` 路径。 #### 路由懒加载 ```jsx import { createBrowserRouter } from 'react-router-dom'; import { Suspense, lazy } from 'react'; const Layout = lazy(() => import('../page/layout')); const About = lazy(() => import('../page/about')); const Home = lazy(() => import('@/page/home')); const router = createBrowserRouter([ { path: "/layout", element: <Layout />, meta: { title: '首页' }, children: [ { index: true, element: <Suspense fallback={'加载中...'}><About /></Suspense>, meta: { title: '关于' } }, { path: '/layout/home', element: <Suspense fallback={'加载中...'}><Home /></Suspense>, meta: { title: '家庭' } } ] } ]); export default router; ``` 此示例展示了如何使用 `lazy` 和 `Suspense` 实现路由懒加载,在用户访问某个路由时才加载和渲染对应的组件,减少应用的初始加载大小,加快页面的加载速度[^3][^4]。 #### 路由守卫 总的来说,React路由守卫是一种用于控制页面访问的机制,它允许在用户尝试访问某个页面之前,执行一些逻辑。通常与路由库结合使用,并使用钩子来执行路由守卫逻辑[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值