严格匹配和Redirect和Replace

1、严格匹配

1、react默认是模糊匹配

什么是模糊匹配,我们来看下面两个小例子

2、怎么开启严格匹配

在注册路由中添加exact或者exact={true} 

1.默认使用的是模糊匹配(简单记:【输入的路径】必须包含要【匹配的路径】,且顺序要一致)

2.开启严格匹配:<Route exact={true} path="/about" component={About}/>

3.严格匹配不要随便开启,需要再开,有些时候开启会导致无法继续匹配二级路由

2、Redirect

刚启动项目的时候会进入http://localhost:3000/这个时候/about和/home都没匹配,如下图:

 如果希望项目一开启默认进去/home怎么办呢?这个时候我们可以使用Redirect组件

        1.一般写在所有路由注册的最下方,当所有路由都无法匹配时,跳转到Redirect指定的路由

        2.具体编码:

            <Switch>

              <Route path="/about" component={About}/>

              <Route path="/home" component={Home}/>

              <Redirect to="/about"/>

            </Switch>

3、Replace

当点击消息1然后点消息2的时候,从消息2可以回退到消息1

如果不希望回退呢?

  •  在路由链接中添加replace或者replace={true} 

 这样这个链接被点击的时候,就不再是用的push进栈而是replace代替栈顶元素

 参考链接:

尚硅谷2021版React技术全家桶全套完整版(零基础入门到精通/男神天禹老师亲授)_哔哩哔哩_bilibili

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值