Skip to content

Latest commit

 

History

History
32 lines (25 loc) · 1.01 KB

useSearchParam.md

File metadata and controls

32 lines (25 loc) · 1.01 KB

useSearchParam

React sensor hook that tracks browser's location search param.

Usage

import {useSearchParam} from 'react-use';

const Demo = () => {
  const edit = useSearchParam('edit');

  return (
    <div>
      <div>edit: {edit || '🤷‍♂️'}</div>
      <div>
        <button onClick={() => history.pushState({}, '', location.pathname + '?edit=123')}>Edit post 123 (?edit=123)</button>
      </div>
      <div>
      <button onClick={() => history.pushState({}, '', location.pathname + '?edit=999')}>Edit post 999 (?edit=999)</button>
      </div>
      <div>
        <button onClick={() => history.pushState({}, '', location.pathname)}>Close modal</button>
      </div>
    </div>
  );
};

Caveats/Gotchas

When using a hash router, like react-router's <HashRouter>, this hook won't be able to read the search parameters as they are considered part of the hash of the URL by browsers.