时间:2021-05-18
通过设置link的path属性,进行路由的传参,当点击link标签的时候,会在上方的url地址中显示传递的整个url
<Link to='/home?name=dx'>首页</Link>如果想真正获取到传递过来的参数,需要在对应的子组件中
this.props.location.search 获取字符串,再手动解析
因为传参能够被用户看见,传递获取比较麻烦,所以不推荐
所谓隐式路由传参,就是传参的信息不回暴露在url中,当点击该link标签,想要获取到传递的参数,就在对应的路由组件中,通过this.props.location.state获取即可
推荐使用,比较安全,获取传递参数都比较方便
何时使用?
当一个路由组件需要接收来自父组件传参的时候
改造route标签通过component属性激活组件的方式
正常情况下的route标签在路由中的使用方式
改造之后
<Link to='/test'>测试</Link><Route path='/test' render={(routeProps) => { //routeProps就是路由组件传递的参数 return ( //在原先路由组件参数的情况,扩展绑定父组件对子组件传递的参数 <Test {...routeProps} name='dx' age={18} /> ) }}></Route>当点击link标签时,通过在对应的test子组件中,this.props获取来自父组件传递的参数和路由组件自带的参数
强烈推荐,传递参数略微有些麻烦,接收参数十分方便,并且仍然可以接收路由组件自带的参数,安全,不会被用户看见
第四种传参方式 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路由传参内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
React中传参方式有很多,通过路由传参的方式也是必不可少的一种。本文记录项目中会用到的路由传参方式:路由跳转传参API+目标路由获取参数的方式。一、动态路由跳
本文实例讲述了vue路由传参的基本实现方式。分享给大家供大家参考,具体如下:前言vue路由传参的使用场景一般都是应用在父路由跳转到子路由时,携带参数跳转。传参方
背景用过VueRouter的童鞋应该对路由传参的方式多多少少有些印象,VueRouter支持两种传参方式:query与params;其中query方式就是动态地
Angular路由传参首页路由传参柳絮飞祭奠$state.go传参数传参数varapp=angular.module("app",['ui.router']);
前言在做微信小程序的时候,经常会遇到需要页面间传递参数的情况,根据目前项目经验,总结了以下几种方式:URL传参、缓存和方法调用。URL传参这种方式是最简单也是最