react-router : share state between Routes without Redux

后端 未结 2 1052
失恋的感觉
失恋的感觉 2021-01-01 05:05

I would like to have a shared state (list of clients fetched remotely) between 2 sibling Routes : Timesheets and Clients.
I want to try how far

相关标签:
2条回答
  • 2021-01-01 05:47

    You can take a look at reacts Context. Redux also makes use of Context. It allows you to pass some data down to all children. But you should write code to use this data, for instance you have determine contextTypes etc.

    You can see details on docs about how to use it.

    0 讨论(0)
  • 2021-01-01 06:00

    You can use an high-order component to fetch and inject data to your top level component. Then you can pass props to sub routes via React.cloneElement.

    HOC

    const FetchHOC = url => Component => class extends React.Component() {
       state = { data: null };
       componentDidMount() { 
          fetch(url).then(data => this.setState({ data })); 
       }
       render() {
          return <Component {...this.props} {...this.state.data} />;
       }
    }
    

    Route configuration

    <Route path="/" component={FetchHOC('http://some-url')(App)}>
       <Route path="subroute1" component={SubRoute1} />
       <Route path="subroute2" component={SubRoute2} />
    </Route>
    

    Parent route render()

    <div className="App">
       {this.props.children && React.cloneElement(this.props.children, {
          data: this.props.data,
          // ...
       })}
    </div>
    
    0 讨论(0)
提交回复
热议问题