react路由中的Switch和exact的使用

Switch

为了解决route的唯一渲染,它是为了保证路由只渲染一个路径。

如果配置了<Switch>

<Router history={history}>
    <Switch>
        <Route path='/home' render={()=>(<div>首页</div>)}/>
        <Route path='/home' component={()=>(<div>首页</div>)}/>
    </Switch>
</Router>

1.jpg

如果没有配置<Switch>

<Router history={history}>
    <Route path='/home' render={()=>(<div>首页</div>)}/>
    <Route path='/home' render={()=>(<div>首页</div>)}/>
</Router>

<Switch>是唯一的,因为它仅仅只会渲染一个路径,当它匹配完一个路径后,就会停止渲染了。相比之下(不使用<Switch>包裹的情况下),每一个被location匹配到的<Route>将都会被渲染。
2.jpeg

exact

只有页面的路由和<Route>path属性精确比对后完全相同该<Route>才会被渲染。

这里想实现一个功能,项目刚进来的时候,路由默认为/,这时候默认进页面路由一,如果页面改成其他的,跳转其他页面。

<Router history={history}>
    <Switch>
        <Route path='/' render={()=>(<div>页面一</div>)}/>
        <Route path='/home' component={()=>(<div>页面二</div>)}/>
    </Switch>
</Router>

5.jpg

会发现不管路由怎么切换,始终渲染的都是path/的页面,这是因为/匹配所有页面,所以不管路由怎么切换,始终渲染页面一。针对以上问题,我们可以采取调整顺序的解决办法,就是将path/的路由放到最后,因为Switch的特性,只要页面匹配完一个路径,它就停止渲染。

<Router history={history}>
    <Switch>
        <Route path='/home' component={()=>(<div>页面二</div>)}/>
        <Route path='/' render={()=>(<div>页面一</div>)}/>
    </Switch>
</Router>

6.jpg

当然,这样可以解决办法,但是如果每次书写路由的话都需要严格控制书写路由顺序的话那代码真的很不优雅,那有没有好的解决办法呢?那肯定必须是有的,官方给我们提供了exact,就是精准匹配。

<Router history={history}>
    <Switch>
        <Route path='/' exact render={()=>(<div>页面一</div>)}/>
        <Route path='/home' component={()=>(<div>页面二</div>)}/>
    </Switch>
</Router>

7.jpg

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值