react中router路由传参和路由的集中管理

简介: 这篇文章来记录一下 在react路由中如何进行路由传参,还有如何进行路由的集中管理

前言

这篇文章来记录一下 在react路由中如何进行路由传参,还有如何进行路由的集中管理

路由传参

1.使用:id进行传参:

<BrowserRouter>
    <ul>
        <li><Link to='/user/:id'>用户中心</Link></li>
        <li><Link to='/userinfo'>用户信息</Link></li>
        <li><Link to='/userdetail'>用户详情</Link></li>
    </ul>
    <Switch>
        <Route path='/user/:id' exact component={User} />
        <Route path='/userinfo' component={UserInfo} />
        <Route path='/userdetail' component={UserDetail} />
    </Switch>
</BrowserRouter>

使用props渲染id

class User extends Component {
    render() {
        console.log(this.props)
        return (
            <div>
                <h1>用户中心</h1>
                <p>{this.props.match.params.id}</p>
            </div>
        )
    }
}

看效果:

在这里插入图片描述

2.路由拼接参数传参

注意看用户信息外面包裹的link标签

<BrowserRouter>
    <ul>
        <li><Link to='/user/:id'>用户中心</Link></li>
        <li><Link to='/userinfo?name=weiwei&age=18'>用户信息</Link></li>
        <li><Link to='/userdetail'>用户详情</Link></li>
    </ul>
    <Switch>
        <Route path='/user/:id' exact component={User} />
        <Route path='/userinfo' component={UserInfo} />
        <Route path='/userdetail' component={UserDetail} />
    </Switch>
</BrowserRouter>

使用querystring解析url传参的值,使用querystring之前要进行安装和引入

class UserInfo extends Component {
    render() {
        console.log(querystring.parse(this.props.location.search))
        let {name, age} = querystring.parse(this.props.location.search)
        return (
            <div>用户信息
                <h2>用户姓名:{name}</h2>
                <h2>用户年龄:{age}</h2>
            </div>
        )
    }
}

查看效果:
在这里插入图片描述

3.对象形式传参

这种方法比较推荐,不会暴露参数而且可以传很多值比较方便
注意看用户详情的link,直接在里面写对象,pathname写地址,state内传对象参数

<BrowserRouter>
    <ul>
        <li><Link to='/user/:id'>用户中心</Link></li>
        <li><Link to='/userinfo?name=weiwei&age=18'>用户信息</Link></li>
        <li><Link to={
            {
                pathname: '/userdetail', // 跳转的路径
                // search: 'name=hello-world'
                state: {name: 'hahaha', age: 12}
            }
        }>用户详情</Link></li>
    </ul>
    <Switch>
        <Route path='/user/:id' exact component={User} />
        <Route path='/userinfo' component={UserInfo} />
        <Route path='/userdetail' component={UserDetail} />
    </Switch>
</BrowserRouter>
class UserDetail extends Component {
    render() {
        console.log(this.props)
        let {name, age} = this.props.location.state
        return (
            <div>用户详情
                <h2>用户姓名:{name}</h2>
                <h2>用户年龄:{age}</h2>
            </div>
        )
    }
}

看效果:
在这里插入图片描述

路由集中管理

学习中我们会发现react中路由比较分散,那么有没有办法对路由进行集中管理呢?
这里需要使用到路由管理器react-router-config,用之前需要安装
然后进行导入就可以使用啦,{renderRoutes(routes)}

import React, { Component } from 'react'
import {BrowserRouter, Link} from 'react-router-dom'
import routes from './07router'
import {renderRoutes} from 'react-router-config'

export class App extends Component {
  render() {
    return (
      <div>
          <BrowserRouter>
            <ul>
                <li><Link to='/'>主页</Link></li>
                <li><Link to='/about'>关于</Link></li>
                <li><Link to='/user'>用户中心</Link></li>
            </ul>

            {renderRoutes(routes)}
          </BrowserRouter>
      </div>
    )
  }
}

export default App

新建一个文件进行路由的相关配置:

import Home from '../01pages/home'
import About from '../01pages/about'
import User from '../01pages/user'

const routes = [
    {
        path: '/',
        exact: true,
        component: Home
    },
    {
        path: '/home',
        exact: true,
        component: Home
    },
    {
        path: '/about',
        component: About
    },
    {
        path: '/user',
        component: User
    }
]

export default routes

这样就可以实现了集中处理路由

路由集中管理之子路由

如果想实现路由包含子路由,怎么实现
看下面

import React, { Component } from 'react'
import {BrowserRouter, Link} from 'react-router-dom'
import routes from './08router'
import {renderRoutes} from 'react-router-config'

export class App extends Component {
  render() {
    return (
      <div>
          <BrowserRouter>
            <ul>
                <li><Link to='/'>主页</Link></li>
                <li><Link to='/about'>关于</Link></li>
                <li><Link to='/about/son'>关于儿子</Link></li>
                <li><Link to='/user'>用户中心</Link></li>
            </ul>

            {renderRoutes(routes)}
          </BrowserRouter>
      </div>
    )
  }
}

export default App

这里还需要新建一个文件写son的内容:

import React, { Component } from 'react'

export class Son extends Component {
  render() {
    return (
      <div>我是关于的Son</div>
    )
  }
}

export default Son

同样的新建文件进行集中管理,子路由就在routes:里面再包一层,看下面的about

// 在这里进行路由的相关配置
import Home from '../01pages/home'
import About from '../01pages/about'
import User from '../01pages/user'
import Son from './son'

const routes = [
    {
        path: '/',
        exact: true,
        component: Home
    },
    {
        path: '/home',
        exact: true,
        component: Home
    },
    
    {
        path: '/about',
        component: About,
        routes: [
            {
                path: '/about/son',
                exact: true,
                component: Son
            }
        ]
    },
    {
        path: '/user',
        component: User
    }
]

export default routes

查看效果:
在这里插入图片描述

好了,本篇文章到这里结束了,如果对你有帮助,可以点赞关注支持一下~~
后续我还会带来更多前端知识内容

相关文章
|
3月前
|
前端开发 JavaScript
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
本文介绍了在React项目中实现路由懒加载的方法,使用React提供的`lazy`和`Suspense`来优化项目首次加载的速度。通过将路由组件改为懒加载的方式,可以显著减少初始包的大小,从而加快首次加载速度。文章还展示了如何使用`Suspense`组件包裹`Switch`来实现懒加载过程中的fallback效果,并提供了使用前后的加载时间对比,说明了懒加载对性能的提升作用。
256 2
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
|
1月前
|
前端开发 API UED
React 路由守卫 Guarded Routes
【10月更文挑战第26天】本文介绍了 React 中的路由守卫(Guarded Routes),使用 `react-router-dom` 实现权限验证、登录验证和数据预加载等场景。通过创建 `AuthContext` 管理认证状态,实现 `PrivateRoute` 组件进行路由保护,并在 `App.js` 中使用。文章还讨论了常见问题和易错点,提供了处理异步操作的示例,帮助开发者提升应用的安全性和用户体验。
55 1
|
1月前
|
前端开发 安全 网络安全
React——路由Route
React——路由Route
36 2
React——路由Route
|
2月前
|
资源调度 前端开发 测试技术
React Router 路由管理
【10月更文挑战第10天】本文介绍了 React Router,一个在 React 应用中管理路由的强大工具。内容涵盖基本概念、安装与使用方法、常见问题及解决方案,如路由嵌套、动态路由和路由守卫等,并提供代码示例。通过学习本文,开发者可以更高效地使用 React Router,提升应用的导航体验和安全性。
325 19
|
2月前
|
前端开发 网络架构
React 路由
10月更文挑战第11天
37 2
|
2月前
|
前端开发 JavaScript 网络架构
实现动态路由与状态管理的SPA——使用React Router与Redux
【10月更文挑战第1天】实现动态路由与状态管理的SPA——使用React Router与Redux
46 1
|
3月前
|
前端开发 Python
React技术栈-React路由插件之自定义组件标签
关于React技术栈中React路由插件自定义组件标签的教程。
66 4
React技术栈-React路由插件之自定义组件标签
|
3月前
|
移动开发 前端开发 应用服务中间件
React两种路由模式的实现原理
React两种路由模式的实现原理
113 3
|
3月前
|
前端开发 程序员 API
React技术栈-React路由插件之react-router的基本使用
这篇博客介绍了React路由插件react-router的基本使用,包括其概念、API、以及如何通过实战案例在React应用中实现SPA(单页Web应用)的路由管理。
90 9
|
4月前
|
前端开发 测试技术 开发者
React Router的神奇之处:如何用导航与路由管理让你的复杂SPA飞起来?
【8月更文挑战第31天】本文全面解析了React Router——一款用于React应用的路由与导航管理库。通过定义不同路径并依据URL渲染组件,React Router支持路径匹配、参数路由及嵌套路由等多种模式。文章详细介绍了其基本与高级用法,如使用`Link`组件导航、`Switch`组件进行路径匹配及`NavLink`自定义活动链接样式。此外,还探讨了懒加载、代码分割等性能优化技巧,并提供了简单示例代码,帮助读者快速上手。遵循本文最佳实践,开发者能够更高效地利用React Router构建复杂的单页面应用。
88 0