A Redux binding for React Router v4
Main features
✨ Synchronize router state with redux store with uni-directional flow (history -> store -> router -> components).
🎁 Support React Router v4.
☀️ Support functional component hot reloading while preserving state (with react-hot-reload v3).
🎉 Dispatching history methods (push
, replace
, go
, goBack
, goForward
) work for both redux-thunk and redux-saga.
⛄️ Nested children can access routing state such as current location directly with react-redux
's connect
.
🕘 Support time traveling in Redux DevTools.
Installation
Using npm:
$ npm install --save connected-react-router
Or yarn:
$ yarn add connected-react-router
Usage
Step 1
- Create a
history
object. - Wrap the root reducer with
connectRouter
and supply thehistory
object to get a new root reducer. - Use
routerMiddleware(history)
if you want to dispatch history actions (ex. to change URL withpush('/path/to/somewhere')
).
......const history = const store =
Step 2
- Wrap your react-router v4 routing with
ConnectedRouter
and passhistory
object as a prop. - Place
ConnectedRouter
as children ofreact-redux
'sProvider
.
......ReactDOM
Now, it's ready to work!
Examples
See examples folder
FAQ
- How to navigate with Redux action
- How to get current URL path
- How to hot reload functional components
- How to hot reload reducers
How to navigate with Redux action
with store.dispatch
store
in redux thunk
const login = { /* do something before redirection */ }
in redux saga
{ /* do something before redirection */ }
How to get current URL path
The current URL path can be accessed directry from the router state with react-redux
's connect
.
const Child = <div> Child receives path path </div> const mapStateToProps = path: staterouterlocationpathname mapStateToPropsChild
How to hot reload functional components
- Separate main app component to another file.
App.js
const App = /* receive history object via props */<ConnectedRouter history=history><div><Match exactly pattern="/" render= <div>Match</div> /><Miss render= <div>Miss</div> /></div></ConnectedRouter>
- Wrap the
App
component withAppContainer
fromreact-hot-loader
v3 as a top-level container.
index.js
...const renderWithHotReload = { // this function will be reused ReactDOM} // render
- Detect change and re-render with hot reload.
index.js
...if modulehotmodulehotaccept'./App' {const NextApp = default}
Now, when you change any component that App
depends on, it will trigger hot reloading without losing redux state. Thanks react-hot-loader v3!
How to hot reload reducers
Detect change and replace with a new root reducer with router state
index.js
...if modulehotmodulehotaccept'./reducers' {const nextRootReducer = defaultstore // Need connectRouter to mount router state}
Build
npm run build
Generated files will be in lib
folder.
Cautions
This is still an experimental project. It relies on several alpha and beta things (i.e. react-hot-loader v3 and react-router v4). Anything can be changed. Bugs are certainly waiting for you to wake them up. Please use it at your own risk.
Contributors
See Contributors and Acknowledge.