react 路由传参

今天,我们要讨论的是react router中Link传值的三种表现形式。分别为通过通配符传参、query传参和state传参。

ps:进入正题前,先说明一下,以下的所有内容都是在react-router V4的版本下。

1.通配符传参

Route定义方式:

<Route path=‘/path/:name‘ component={Path}/>

Link组件:

HTML方式

<Link to="/path/通过通配符传参">通配符</Link>

JS方式

this.props.router.push(‘/path/‘+‘参数‘)

参数获取:

this.props.match.params.name

注意这个match,许多博客活文章都是忽略了它,导致取不到值。这里的this.props.match.params.name === ‘通过通配符传参’。

优点:简单快捷,并且,在刷新页面的时候,参数不会丢失。

缺点:只能传字符串,并且,如果传的值太多的话,url会变得长而丑陋。

如果,你想传对象的话,可以用JSON.stringify(),想将其转为字符串,然后另外的页面接收后,用JSON.parse()转回去。这里简单提一下,不赘述。

2.query

Route定义方式:

<Route path=‘/query‘ component={Query}/>

Link组件:

HTML方式

var query = {
  pathname: ‘/query‘,
  query: {day: ‘Friday‘}
}

<Link to={query}>query</Link>

JS方式

this.props.history.push({ pathname : ‘/query‘ ,query : { day: ‘Friday‘} })

参数获取:

this.props.location.query.day

这里的this.props.location.query === ‘我是通过query传值‘

优点:优雅,可传对象

缺点:刷新页面,参数丢失

3.state

Route定义方式:

<Link to={state}>state</Link>

Link组件:

HTML方式

var state = {
  pathname: ‘/state‘,
  state: ‘我是通过state传值‘
}
<Route path=‘/state‘ component={State}/>

JS方式

 this.props.router.push({ pathname:‘/sort‘,state:{name : ‘sunny‘ } })

参数获取:

this.props.location.state

这里的this.props.location.state === ‘我是通过query传值‘

优点:优雅,可传对象

缺点:刷新页面,参数丢失

原文地址:https://www.cnblogs.com/crazycode2/p/9261630.html

时间: 2024-10-12 08:12:09

react 路由传参的相关文章

react路由传参

今天,我们要讨论的是react router中Link传值的三种表现形式.分别为通过通配符传参.query传参和state传参. ps:进入正题前,先说明一下,以下的所有内容都是在react-router V4的版本下. 1.通配符传参 Route定义方式: <Route path='/path/:name' component={Path}/> Link组件: <Link to="/path/通过通配符传参">通配符</Link> 参数获取: th

react做路由跳转,路由传参 &#340936;

原文: http://blog.gqylpy.com/gqy/496 置顶:来自一名75后老程序员的武林秘籍--必读(博主推荐) 来,先呈上武林秘籍链接:http://blog.gqylpy.com/gqy/401/ 你好,我是一名极客!一个 75 后的老工程师! 我将花两分钟,表述清楚我让你读这段文字的目的! 如果你看过武侠小说,你可以把这个经历理解为,你失足落入一个山洞遇到了一位垂暮的老者!而这位老者打算传你一套武功秘籍! 没错,我就是这个老者! 干研发 20 多年了!我也年轻过,奋斗过!我

vue-router和react-router-dom路由传参对照

React 1.动态路由传参 <Route exact path="/detail/:id" component={Detail}/> 接收 componentDidMount() { console.log(this.props.match.params); } 2.函数传参(push)加密的地址栏不可见 <button onClick={() => this.props.history.push({ pathname: '/detail', state: {

8.MVC框架开发(URL路由配置和URL路由传参空值处理)

1.ASP.NET和MVC的路由请求处理 1)ASP.NET的处理 请求---------响应请求(HttpModule)--------处理请求(HttpHandler)--------把请求的资源处理之后返回给客户端 2)MVC的处理 由ASP.NET衍生出来,也遵循请求.响应.处理.资源返回给客户端的过程 请求-----URLRoutingModule(响应路由请求)-----RoutingTable(路由表)(检索请求路径是否和路由表里的路由匹配)-----生成一个路由映射,生成一个Ro

vue路由传参query和params的区别

1.用法 A.query要用path来引入(用name来引入也可以),接收参数都是this.$route.query.name. B.params要用name来引入,接收参数都是this.$route.params.name. 2.效果 A.query类似于ajax中get传参,即在浏览器地址栏中显示参数. B.params则类似于post,即在浏览器地址栏中不显示参数. 3.个人建议 在路由传参上建议使用params,以隐藏参数,做好安全保密.

小程序路由传参的时候出现数据丢失

在写把操作的答案通过路由传参的形式传到下一个页面的时候,在下一个页面获取的时候数据被截取了 解决办法 使用  encodeURIComponent        进行加密 然后再另外一个页面获取的时候使用     decodeURIComponent 进行解码 这样就解决了路由传参时数据丢失的情况了 原文地址:https://www.cnblogs.com/jeremy-o/p/9934468.html

Vue路由传参及传参后刷新导致参数消失处理

参考:https://blog.csdn.net/qq_43103581/article/details/82260073(vue 路由传递参数,刷新页面后参数丢失) 项目功能需要,要从列表页跳转到第三方提供的URL上(这里第三方页面我是通过iframe引入在详情页,目的是点击返回时可以通过keepAlive让列表页不刷新,如果不通过iframe直接跳第三方链接,那么返回必然会重新拉取数据),一路百度,刚开始使用 this.$router.push({name:'list', params:{i

Vue路由传参的几种方式

原 Vue路由传参的几种方式 2018年07月28日 23:52:40 广积粮缓称王 阅读数 12613 前言:顾名思义,vue路由传参是指嵌套路由时父路由向子路由传递参数,否则操作无效.传参方式可以划分为params传参和query传参,params传参又可以分为url中显示参数和不显示参数两种方式.具体区分和使用后续分析. 参考官网:https://router.vuejs.org/zh/guide/essentials/navigation.html params传参(url中显示参数)

小程序路由传参

这里会有一个问题,如果要传字符还好说,如果是boolean值传过去 ,接收过来还是字符串 小程序路由跳转有两种方式: wx.navigateTo() 会后退按钮:  wx.redirectTo() 不会有路由跳转 1.wx.navigateTo() 路由跳转 2.wx.redirectTo() 路由重定向 3.navigateBack() 页面返回 还有几个 可以看看 这位大佬 写的详细些  https://www.cnblogs.com/cckui/p/10007976.html  (我写呢