2

我已经尝试了几种组合,但如果有任何路线被击中(未声明)但我认为不会<Route path="*" component={PageNotFound}/>着陆。PageNotFound/

还有其他方法还是我做错了什么?该应用程序的其余部分似乎运行良好。

import * as React from 'react'
import {BrowserRouter as Router, Route, Switch } from 'react-router-dom'

export const Routes = () => (
  <Router>
    <div>
      <Switch>
        <Route exact path="/login" component={Login}/>
        <MainApp>
          <Route path="/list" component={List}/>
          <Route path="/settings" component={Settings}/>
          <Switch>
            <User path="/user" >
              <Switch>
                <Route exact path="/user/staticUser" component={UserStatic} />
                <Route exact path="/user/:id" component={UserID} />
              </Switch>
            </User>
          </Switch>
        </MainApp>
        <Route path="*" component={PageNotFound}/>
      </Switch>
    </div>
  </Router>
)

更多信息:

/ - Home - parent of all (almost)
/List - inside home
/Settings - inside home
/Login - standalone
/Users - inside home, For now just showing itself. It has further pages.
/User/123 - inside user with /:id
/User/staticUser - inside user with static route
/garbage - not a route defined (not working as expected)
4

1 回答 1

3

使用 react-router-dom 包 (v4)

如果您希望NoMatchFound在与应用程序中的特定路由不匹配时呈现组件,则只需指定<Route>不带路径的 a。

像这样的东西-<Route component={NoMatch} />

这是我的应用程序中的路由示例。

```

  <Router>
    <AppContainer>
      <Route component={Header} />
      <Switch>
        <Route exact path="/" component={MDashboard} />

        <Route path="/monitor/:groupId/:tab" component={Monitor} />
        <Route path="/monitor/:groupId" component={Monitor} />
        <Route exact path="/insights" component={IDashboard} />

        <Route component={NoMatch} />
      </Switch>
    </AppContainer>
  </Router>

```

于 2017-04-10T20:41:21.907 回答