Ant Design-ReactRouter

记录一下,现在的实际场景是,同一个模块的两个url用的是同一个页面模块,一开始url切换的时候页面并没有刷新,也就是说,即使页面来回切换,url不同,componentDidMount 也只执行一次,这是由于Router 的 Key 相同 要解决这个问题,设置两个不一样的key就好

routeArr = [
	{
      path: '/project/list/:id',
      component: ProjectPage
    }
]

<Switch>
 {routeArr.map(route => {
    const Item = route.component;
      return (
        <Route
          key={route.path}
          path={route.path}
          exact={route.exact}
          render={props => {
            return (
             <Item  {...this.props} />
			)
          }}
        />
      );
  	}
  )}
</Switch>

由上面例子所示,由于两个侧边栏,一个url 是 ‘/project/list/111’, 一个是 ‘/project/list/222’, 所以他们都可以匹配 '/project/list/:id‘, 这也到这他们 Route 的key属性一样,改一下就好了

routeArr = [
	{
      path: '/project/list/111',
      component: ProjectPage
    },
    {
      path: '/project/list/222',
      component: ProjectPage
    }
]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值