美文网首页技术开源共享
react路由中的Switch和exact的使用

react路由中的Switch和exact的使用

作者: _hider | 来源:发表于2019-07-28 15:26 被阅读0次
    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

    相关文章

      网友评论

        本文标题:react路由中的Switch和exact的使用

        本文链接:https://www.haomeiwen.com/subject/ydpnlctx.html