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


Posted in Javascript onMarch 23, 2021

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

通过设置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';
//导入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)

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

Javascript 相关文章推荐
Jquery实战_读书笔记2 选择器
Jan 22 Javascript
javascript与CSS复习(二)
Jun 29 Javascript
颜色选择器 Color Picker,IE,Firefox,Opera,Safar
Nov 25 Javascript
c#和Javascript操作同一json对象的实现代码
Jan 17 Javascript
javascript setinterval 的正确语法如何书写
Jun 17 Javascript
使用JavaScript和C#中获得referer
Nov 14 Javascript
node.js中的fs.writeFile方法使用说明
Dec 14 Javascript
window.location.reload 刷新使用分析(去对话框)
Nov 11 Javascript
Vue请求JSON Server服务器数据的实现方法
Nov 02 Javascript
详解vue组件中使用路由方法
Feb 12 Javascript
基于vue与element实现创建试卷相关功能(实例代码)
Dec 07 Vue.js
js+for循环实现字符串自动转义的代码(把后面的字符替换前面的字符)
Dec 24 Javascript
一百多行代码实现react拖拽hooks
node中使用shell脚本的方法步骤
详解如何解决使用JSON.stringify时遇到的循环引用问题
vue 中 get / delete 传递数组参数方法
Mar 23 #Vue.js
JavaScript实现页面动态验证码的实现示例
使用Vue.js和MJML创建响应式电子邮件
JS原生实现轮播图的几种方法
You might like
浅析ThinkPHP中的pathinfo模式和URL重写
2014/01/06 PHP
用 Composer构建自己的 PHP 框架之设计 MVC
2014/10/30 PHP
PHP中使用file_get_contents post数据代码例子
2015/02/13 PHP
php从csv文件读取数据并输出到网页的方法
2015/03/14 PHP
PHP论坛实现积分系统的思路代码详解
2020/06/01 PHP
php中使用array_filter()函数过滤数组实例讲解
2021/03/03 PHP
JavaScript 数组的 uniq 方法
2008/01/23 Javascript
jquery 简单的进度条实现代码
2010/03/11 Javascript
ionic js 复选框 与普通的 HTML 复选框到底有没区别
2016/06/06 Javascript
第八篇Bootstrap下拉菜单实例代码
2016/06/21 Javascript
详解jQuery简单的表单应用
2016/12/16 Javascript
浅谈Vue的基本应用
2016/12/27 Javascript
谈谈vue中mixin的一点理解
2017/12/12 Javascript
vue-cli3.0使用及部分配置详解
2018/08/29 Javascript
vue组件(全局,局部,动态加载组件)
2018/09/02 Javascript
jQuery实现侧边栏隐藏与显示的方法详解
2018/12/22 jQuery
vux-scroller实现移动端上拉加载功能过程解析
2019/10/08 Javascript
vue中英文切换实例代码
2020/01/21 Javascript
[02:43]DOTA2英雄基础教程 圣堂刺客
2013/12/09 DOTA
python网络编程之数据传输UDP实例分析
2015/05/20 Python
Python利用flask sqlalchemy实现分页效果
2020/08/02 Python
python中is与双等于号“==”的区别示例详解
2017/11/21 Python
基于TensorFlow中自定义梯度的2种方式
2020/02/04 Python
使用PyQt5实现图片查看器的示例代码
2020/04/21 Python
使用Python pip怎么升级pip
2020/08/11 Python
详解Python流程控制语句
2020/10/28 Python
美体小铺加拿大官方网站:The Body Shop加拿大
2016/10/30 全球购物
安德玛菲律宾官网:Under Armour菲律宾
2020/07/28 全球购物
Vector, ArrayList, HashTable, HashMap哪些是线程安全的,哪些不是
2015/10/12 面试题
年度考核自我评价
2014/01/25 职场文书
社区综治宣传月活动总结
2014/07/02 职场文书
财务总监岗位职责
2015/02/03 职场文书
教师年度考核个人总结
2015/02/12 职场文书
汽车4S店前台接待岗位职责
2015/04/03 职场文书
《最后一头战象》读后感:动物也有感情
2020/01/02 职场文书
Python学习之包与模块详解
2022/03/19 Python