首页前端开发JavaScript浅谈react路由传参的几种方式

浅谈react路由传参的几种方式

时间2024-02-01 04:58:02发布访客分类JavaScript浏览767
导读:收集整理的这篇文章主要介绍了浅谈react路由传参的几种方式,觉得挺不错的,现在分享给大家,也给大家做个参考。 第一种传参方式,动态路由传参通过设置link的path属性,进行路由的传参...
收集整理的这篇文章主要介绍了浅谈react路由传参的几种方式,觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

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

如果想真正获取到传递过来的参数,需要在对应的子组件中
this.PRops.location.seArch 获取字符串,再手动解析

因为传参能够被用户看见,传递获取比较麻烦,所以不推荐

第二种传参方式,隐式路由传参

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

所谓隐式路由传参,就是传参的信息不回暴露在url中,当点击该link标签,想要获取到传递的参数,就在对应的路由组件中,通过this.props.location.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';
//导入withRouteimport {
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)

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

到此这篇关于浅谈react路由传参的几种方式的文章就介绍到这了,更多相关react路由传参内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

您可能感兴趣的文章:
  • 详解React路由传参方法汇总记录
  • React组件通信之路由传参(react-router-dom)

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: 详解如何解决使用JSON.stringify...下一篇:一百多行代码实现react拖拽hooks猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员loadpost-format-gallery

若转载请注明出处: 浅谈react路由传参的几种方式
本文地址: https://pptw.com/jishu/594950.html
JavaScript实现页面动态验证码的实现示例 C语言中要改变循环语句的流程可以使用的语句有哪些

游客 回复需填写必要信息