i have following basic structure of nested routes/components react app:
/users
->
userslist
/users/:id
->
userlayout
/users/:id/
->
userprofile
/users/:id/settings
->
usersettings
/users/:id/blah
->
yetanothercomponent
what i'm trying figure out, in context of react router v4, how access :id
parameter in usersettings
component. can access fine in userlayout
component, else further downstream.
my main router definition lies in home
component, user-specific routes contain same header information want user-specific routes nested. current structure has these nested routes defined in userlayout
component. however, no matter layout component's route definition, cannot other route "index" route (userprofile
) render. when trying access usersettings
or other route, top level 404 route gets hit instead.
here's relevant jsx (snippets of actual components' render
functions):
home
<main> <switch> <route exact path="/login" component={login} /> <route exact path="/users" component={userslist} /> <route exact path="/users/:id" component={userlayout} /> <route exact path="/" component={home} /> <route component={nomatch} /> </switch> </main>
userlayout
<div> <switch> <route path={`${match.url}/settings`} component={usersettings} /> <route path="/users/:id/blah" component={yetanothercomponent} /> </switch> <route path="/users/:id" component={userprofile} /> </div>
in userlayout
component i've tried both path formats shown in switch
, have tried turning on/off exact matching. thing can come using route
component's render
parameter pass id parameter, seems wrong. option?
of course few minutes after post, figured out. in top-level route config, had set /user/:id
require exact match. meant when navigated /user/:id/anything_else
react router didn't load userlayout
@ , didn't chance test remainder of routes had configured.
so changed home component:
<route exact path="/users/:id" component={userlayout} />
...to this:
<route path="/users/:id" component={userlayout} />
... , world.
Comments
Post a Comment