Skip to content

Latest commit

 

History

History
39 lines (28 loc) · 1.81 KB

README.md

File metadata and controls

39 lines (28 loc) · 1.81 KB

React_NavLink

dynamic variable path in URL

NavLink (a Route with a dynamic param)

A Route can have a path that is dynamic or follow regex like pattern. For example, a Route can render a component if path is /about/xyz but xyz can be any variable string. This string is called as parameter and passed down to the component in match prop inside params object. If you want to introduce a Route with a dynamic parameter, then that parameter start with the colon : in the path like /about/:xyz so that React Router understands that xyz is a dynamic parameter.

const Contact = ( props ) => (
    <div>        
        <h1>Contact Component</h1>
        <div className="links">
            <NavLink to={ `${props.match.url}/india` }
            className="link">India Office</NavLink>
            <NavLink to={ `${props.match.url}/us` }
            className="link">Us Office</NavLink>
        </div>
        <Switch>
            <Route exact path={ props.match.url }
            render={ () => <h4>Please select an office.</h4> }/>
            <Route path={ `${props.match.url}/:location` }
            component={ ContactInfo }/>

        <Route render={ () => <h2>No office found.</h2> }/>
    </Switch>
</div>
);

const ContactInfo = ( props ) => <h1>Welcome to { props.match.params.location } office.</h1>;

In above case, ContactInfo can also resolve /contact/japan which we don’t want because that’s not in our business case. Hence, to tell Route to only render ContactInfo component when location parameter is either us or india, we need to use regex pattern like below.

  <Route path={ `${props.match.url}/:location(india|us)` }
  component={ ContactInfo }/>

Ref Doc

https://medium.com/jspoint/basics-of-react-router-v4-336d274fd9e0