浅谈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 ajax执行后台方法
Mar 18 Javascript
jquery 操作表格实现代码(多种操作打包)
Mar 20 Javascript
Jquery实现视频播放页面的关灯开灯效果
May 27 Javascript
JS.getTextContent(element,preformatted)使用介绍
Sep 21 Javascript
jquery解析XML字符串和XML文件的方法说明
Feb 21 Javascript
JS的框架Polymer中的dom-if和is属性使用说明
Jul 29 Javascript
神奇!js+CSS+DIV实现文字颜色渐变效果
Mar 16 Javascript
快速解决select2在bootstrap模态框中下拉框隐藏的问题
Aug 10 Javascript
webuploader分片上传的实现代码(前后端分离)
Sep 10 Javascript
JavaScript实现多张图片放大镜效果示例【不限定图片尺寸,rem单位】
May 14 Javascript
js基础之事件捕获与冒泡原理
Oct 09 Javascript
Element-ui upload上传文件限制的解决方法
Jan 22 Javascript
一百多行代码实现react拖拽hooks
node中使用shell脚本的方法步骤
详解如何解决使用JSON.stringify时遇到的循环引用问题
vue 中 get / delete 传递数组参数方法
Mar 23 #Vue.js
JavaScript实现页面动态验证码的实现示例
使用Vue.js和MJML创建响应式电子邮件
JS原生实现轮播图的几种方法
You might like
生成静态页面的PHP类
2006/07/15 PHP
php getsiteurl()函数
2009/09/05 PHP
PHP封装分页函数实现文本分页和数字分页
2014/10/23 PHP
PHP基于imap获取邮件实例
2014/11/11 PHP
PHP中的流(streams)浅析
2015/07/02 PHP
PHP读取CSV大文件导入数据库的实例
2017/07/24 PHP
Yii2.0框架behaviors方法使用实例分析
2019/09/30 PHP
Javascript中的相等与不等运算
2010/04/25 Javascript
按给定几率进行随机抽取的js代码
2010/12/28 Javascript
JavaScript数组随机排列实现随机洗牌功能
2015/03/19 Javascript
jQuery实现带渐显效果的人物多级关系图代码
2015/10/16 Javascript
AngularJS入门教程之多视图切换用法示例
2016/11/02 Javascript
利用Plupload.js解决大文件上传问题, 带进度条和背景遮罩层
2017/03/15 Javascript
Node.js设置CORS跨域请求中多域名白名单的方法
2017/03/28 Javascript
vue中动态设置meta标签和title标签的方法
2018/07/11 Javascript
vue2.x集成百度UEditor富文本编辑器的方法
2018/09/21 Javascript
React 源码中的依赖注入方法
2018/11/07 Javascript
[03:49]辉夜杯现场龙骑士COSER秀情商“我喜欢芬队!”
2015/12/27 DOTA
[01:15:00]LGD vs Mineski Supermajor 胜者组 BO3 第一场 6.5
2018/06/06 DOTA
数据挖掘之Apriori算法详解和Python实现代码分享
2014/11/07 Python
在cmd中运行.py文件: python的操作步骤
2018/05/12 Python
numpy求平均值的维度设定的例子
2019/08/24 Python
Django1.11自带分页器paginator的使用方法
2019/10/31 Python
Python通过TensorFLow进行线性模型训练原理与实现方法详解
2020/01/15 Python
python3 kubernetes api的使用示例
2021/01/12 Python
Oroton中国官网:澳洲知名奢侈配饰品牌
2017/03/26 全球购物
英国户外装备商店:Ultimate Outdoors
2019/05/07 全球购物
幼儿园教师教学反思
2014/02/06 职场文书
精彩的广告词
2014/03/19 职场文书
党小组评议意见
2015/06/02 职场文书
小学运动会入场词
2015/07/18 职场文书
2015年度个人工作总结报告
2015/10/24 职场文书
Html5新增了哪些功能
2021/04/16 HTML / CSS
python实现Thrift服务端的方法
2021/04/20 Python
Nginx 常用配置
2022/05/15 Servers
MySQL分布式恢复进阶
2022/07/23 MySQL