Skip to content

Latest commit

Β 

History

History
34 lines (27 loc) Β· 1.14 KB

useSearchParam.md

File metadata and controls

34 lines (27 loc) Β· 1.14 KB

useSearchParam

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

Usage

import {useSearchParam} from 'vue-next-use';

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

      return () => (
          <div>
              <div>edit: {edit.value || 'πŸ€·β€β™‚οΈ'}</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.