react路由传参的几种方式[通俗易懂]

react路由传参的几种方式[通俗易懂]第一种传参方式,动态路由传参通过设置link的path属性,进行路由的传参,当点击link标签的时候,会在上方的url地址中显示传递的整个url<Linkto=’/home?name=dx’>首页</Link>如果想真正获取到传递过来的参数,需要在对应的子组件中this.props.location.search获取字符串,再手动解析因为传参能够被用户看见…

大家好,又见面了,我是你们的朋友全栈君。

第一种传参方式,动态路由传参

<Link to='/home/dx'>首页</Link>

<Route path="/home/:name" component={ 
   Home}>

‘dx’为被传递的字符串,在home组件中 通过

this.props.match.params

会收到

{ 
    name: 'dx' }

优点:
1、‘传参和接收都比较简单’
2、刷新页面参数不会丢失
缺点:
1、 ‘当复杂数据对象或数组需要传参时,这样做比较麻烦,需要通过json字符串的方式进行处理’
2、多个参数的传递不方便
3、参数会出现在url上,不够安全

动态路由一般都是用来传递某个唯一的值,比如详情或编辑的id

第二种传参方式,search传参
通过设置link的path属性,进行路由的传参,当点击link标签的时候,会在上方的url地址中显示传递的整个url

<Link to='/home?name=dx'>首页</Link>

在这里插入图片描述
如果想真正获取到传递过来的参数,需要在对应的子组件中

this.props.location.search 

获取字符串,再手动解析

或者

this.props.location.query

优点:
1、‘传参和接收都比较简单’
2、刷新页面参数不会丢失
3、可以传递多个参数
缺点:
1、‘当复杂数据对象或数组需要传参时,这样做比较麻烦,需要通过json字符串的方式进行处理’
2、参数会出现在url上,不够安全

第三种传参方式,隐式路由state传参

<Link to={ 
   { 
   
          pathname: 'about',
          state: { 
   
            name: 'dx'
          }
        }}>关于</Link>

所谓隐式路由传参,就是传参的信息不回暴露在url中,当点击该link标签,想要获取到传递的参数,就在对应的路由组件中,通过

this.props.location.state

获取即可

优点:
1、‘传参和接收都比较简单’
2、可以传递多个参数
3、传递对象数组等复杂参数方便
4、不会暴露给用户,比较安全
缺点:
1、如果手动刷新当前路由时,数据参数有可能会丢失!!!’
在react中,最外层包裹了BrowserRouter时,不会丢失,但如果使用的时HashRouter,刷新当前页面时,会丢失state中的数据

第四种传参方式 组件间传参

何时使用?
当一个路由组件需要接收来自父组件传参的时候

改造route标签通过component属性激活组件的方式
正常情况下的route标签在路由中的使用方式

//简洁明了,但没办法接收来自父组件的传参
<Route path='/test' component={ 
   Test}></Route>

改造之后

<Link to='/test'>测试</Link>
<Route path='/test' render={ 
   (routeProps) => { 
   
		//routeProps就是路由组件传递的参数
          return (
          //在原先路由组件参数的情况,扩展绑定父组件对子组件传递的参数
            <Test { 
   ...routeProps} name='dx' age={ 
   18} />
          )
 }}></Route>	

当点击link标签时,通过在对应的test子组件中,this.props获取来自父组件传递的参数和路由组件自带的参数
强烈推荐,传递参数略微有些麻烦,接收参数十分方便,并且仍然可以接收路由组件自带的参数,安全,不会被用户看见

最后一种传参方式 withRouter 高阶组件给子组件绑定路由参数

withRouter 何时使用?
想要在某个子组件中获取路由的参数,必须得使用路由中的route标签的子组件才能被绑定上路由的参数。

为了解决不通过route标签绑定的子组件获取路由参数的问题,需要使用withRouter

一般用在返回首页,返回上一级等按钮上

import React from 'react';
import BackHome from './backhome';
export default class Test extends React.Component { 
   
  render () { 
   
    console.log(this.props)
    return (
      <div>
        这是测试的内容
//返回首页的按钮不是通过route标签渲染的,所以该子组件的this.props中没有路由参数
        <BackHome>返回首页</BackHome> 
      </div>
    )
  }
}
import React from 'react';
//导入withRoute
import { 
   withRouter} from 'react-router-dom';
class BackHome extends React.Component { 
   
  goHome = () => { 
   
  	//必须在使用withRouter的情况下,该组件在this.props中才有路由参数和方法
  	//否则,会报错
    this.props.history.push({ 
   
      pathname: '/home',
      state: { 
   
        name: 'dx' //同样,可以通过state向home路由对应的组件传递参数
      }
    })
  }
  render () { 
   
    return (
      <button onClick={ 
   this.goHome}>this.props.children</button>
    )
  }
}
//导出的时候,用withRouter标签将backHome组件以参数形式传出
export default withRouter(BackHome)

当你需要使用的时候,就很重要,所以还是比较推荐。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/132263.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux网络配置出现E325,打开Vi编辑器出现E325: ATTENTION的解决方法

    linux网络配置出现E325,打开Vi编辑器出现E325: ATTENTION的解决方法当打开Vi编辑器时出现以下的提示时不要着急E325:ATTENTIONFoundaswapfilebythename”/etc/.profile.swp”ownedby:rootdated:WedJul1410:01:102010filename:/etc/profilemodified:YESusername:roothostname:zh…

    2022年5月19日
    49
  • 百度云里视频在线播放, 字幕乱码的解决办法

    百度云里视频在线播放, 字幕乱码的解决办法这几天折腾了一下百度云,放了个电影准备外出的时候看,结果找了一个没字幕,从射手上下载了字幕以后浏览器里一播放发现居然是乱码查看了一下字幕,在编辑器里看着没问题,于是猜想是不是编码的问题用UE

    2022年7月4日
    26
  • [Python人工智能] 九.gensim词向量Word2Vec安装及《庆余年》中文短文本相似度计算

    [Python人工智能] 九.gensim词向量Word2Vec安装及《庆余年》中文短文本相似度计算从本专栏开始,作者正式开始研究Python深度学习、神经网络及人工智能相关知识。前一篇详细讲解了卷积神经网络CNN原理,并通过TensorFlow编写CNN实现了MNIST分类学习案例。本篇文章将分享gensim词向量Word2Vec安装、基础用法,并实现《庆余年》中文短文本相似度计算及多个案例。本专栏主要结合作者之前的博客、AI经验和相关文章及论文介绍,后面随着深入会讲解更多的Python人工智能案例及应用。基础性文章,希望对您有所帮助~

    2022年6月8日
    29
  • 深入理解DOM节点类型第七篇——文档节点DOCUMENT

    深入理解DOM节点类型第七篇——文档节点DOCUMENT

    2021年9月17日
    44
  • 基于单片机的交通信号灯系统设计开题报告_51单片机交通信号灯设计

    基于单片机的交通信号灯系统设计开题报告_51单片机交通信号灯设计十字路口车辆穿梭,行人熙攘,车行车道,人行人道,有条不紊。那么靠什么来实现这井然秩序呢?靠的就是交通信号灯的自动指挥系统。设计功能描述:1、采用51单片机作为主控单元;2、采用74HC245芯片驱动数码管;3、采用数码管显示倒计时时间;4、东西和南北方向各有两个数码管,分别显示时间,东西和南北的时间是不一样的,相差黄灯的时间才是正确的;5、可分别设置主干道和支干道通行时间;6、具有紧急模式,特种车辆优先通行或交通事故应急处理。按键说明:K1:黄灯长亮…

    2022年9月2日
    2
  • 微服务分布式事务解决方案_微服务追踪与监控

    微服务分布式事务解决方案_微服务追踪与监控目录Sleuth简介相关术语使用Sleuth引入依赖创建服务product-serviceorder-service启动&测试Zipkin使用Zipkin参考文章Sleuth简介Sleuth是SpringCloud的组件之一,它为SpringCloud实现了一种分布式追踪解决方案,兼容Zipkin,HTrace和其他基于日志的追踪…

    2025年7月7日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号