私はいくつかの組み合わせを試しましたが、ルートがヒットした場合(宣言されていない場合)<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)