useReactRouter
is a React Hook that provides pub-sub behavior for react-router
.
Unlike the withRouter
Higher-Order Component, useReactRouter
will re-render your component when the location changes!
useReactRouter()
returns the an object that contains the history
, location
, and match
properties that would be passed as props by the HOC.
Pub-sub behavior is a common request (that's commonly rejected) for the react-router
package.
For users who adamently prefer pub-sub behavior over react-router
's suggested alternatives, this package offers a solution.
A non-pub-sub React Hook is anticipated to eventually be included in the react-router
package itself.
You must be using react-router
v4.4.0 or greater. At time of publication, you must install react-router@next
in order to grab the 4.4.0 package.
npm install use-react-router
oryarn add use-react-router
Import useReactRouter
and use it as a React Hook.
import useReactRouter from 'use-react-router';
const MyPath = () => {
const { history, location, match } = useReactRouter();
return (
<div>
My location is {location.pathname}!
</div>
);
};