首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >阻止react路由

阻止react路由
EN

Stack Overflow用户
提问于 2019-04-18 00:47:00
回答 1查看 580关注 0票数 0

我使用了一个名为Core-UI的主题,代码中的路由略有不同。我对如何阻止app.js上最终通向所有路由的特定路由感到困惑。

我已经尝试了相关主题中的解决方案,但没有成功。

这是来自app.js的

代码语言:javascript
复制
<BrowserRouter>
      <React.Suspense fallback={loading()}>
        <Switch>
          <Route exact path="/" name="Login Page" render={props => <Login {...props} />} />
          <Route exact path="/login" name="Login Page" render={props => <Login {...props} />} />
          <Route exact path="/404" name="Page 404" render={props => <Page404 {...props} />} />
          <Route exact path="/500" name="Page 500" render={props => <Page500 {...props} />} />
          <Route path="/" name="Home" render={props => <DefaultLayout {...props} />} />
        </Switch>
      </React.Suspense>

代码语言:javascript
复制
<Route path="/" name="Home" render={props => <DefaultLayout {...props} />} />

这是我想使用localStorage拦截的路由。我试过了,但是失败了:

代码语言:javascript
复制
<Route path="/" name="Home" render={props => 
            localStorage.getItem('jwtToken') !== null
            ? (
              <DefaultLayout {...props} />
            ) : (
              <Redirect to={{ pathname: "/login" }} />
            )
          } 
/>

如果需要任何其他文件,我会提供它们。谢谢。

EN

回答 1

Stack Overflow用户

发布于 2019-04-18 01:03:08

根据您的代码,您有两条通往"/“login和home的路由

代码语言:javascript
复制
   <Switch>
          <Route path="/" name="Home" render={props => 
            localStorage.getItem('jwtToken') !== null
            ? (
              <DefaultLayout {...props} />
            ) : (
              <Redirect to={{ pathname: "/login" }} />
            )
          } />

          <Route exact path="/login" name="Login Page" render={props => <Login {...props} />} />
          <Route exact path="/login" name="Login Page" render={props => <Login {...props} />} />
          <Route exact path="/404" name="Page 404" render={props => <Page404 {...props} />} />
          <Route exact path="/500" name="Page 500" render={props => <Page500 {...props} />} />
          <Route path="/" name="Home" render={props => <DefaultLayout {...props} />} />
        </Switch>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55732486

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档