React入门随记——路由传值

路由的两种方式:

to:
    1、字符串:"/one"
    2、对象:{pathname:'/one'}

  <NavLink className={"App-link"} activeClassName={"App-active"} to={"/one"}>One</NavLink>
 <NavLink className={"App-link"} activeClassName={"App-active"} to={{ pathname: '/one', query: { a: 1, b: { id: 12, type: 88 } } }}>One</NavLink>

传值都用第二种方式

********************路由传值************************************************************

********1、通过query形式进行传值*********

<NavLink
      className={"App-link"}
      activeClassName={"App-active"}
      to={{pathname:'/one',query:{a:1,b:2}}}>One</NavLink>

接受值:在one.jsx中 ,通过 this.props.location.query,它可以传递对象

缺点:刷新数据丢失

********2、state方式*********

<NavLink
      className={"App-link"}
      activeClassName={"App-active"}
      to={{
          pathname:'/two',
          state:{c:3,d:{id:2,type:90}}
      }}>Two</NavLink>

通过 this.props.location.state 

特点:刷新不会丢失。可以接收对象。*如果该地址重新打开数据会丢失。

********3、params传值 *********

 <NavLink className={"App-link"}
       activeClassName={"App-active"}
       to={{pathname:'/three/1/33'}}>Three</NavLink>

通过 this.props.match.params 接受值

特点:刷新数据不会丢失。不可以直接传对象。

可以这样玩:

<NavLink className={"App-link"}
                        activeClassName={"App-active"}
                        to={"/three/19-39.html"}>Three</NavLink>
 <Route component={Three} path={"/three/:id-:type.html"}></Route>

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值