Skip to content

Latest commit

 

History

History
56 lines (45 loc) · 1.57 KB

useQueryParam.md

File metadata and controls

56 lines (45 loc) · 1.57 KB

useQueryParam

A hook built on top of React Router v5 that facilitate access and manipulation of query parameters.

Why? 💡

  • Facilitates editing the query string in the URL for the current location
  • Functions similarly to the useState hook
  • Does not rely on version 6 of the useSearchParams function from react-router-dom, ensuring compatibility with older versions

Basic Usage:

import { useState, useRef } from 'react';
import { HashRouter as Router } from 'react-router-dom'
import { Typography, Tag, Input } from 'antd';
import useQueryParam from 'beautiful-react-hooks/useQueryParam';

const ExampleComponent = () => {
  // second parameter is optional
  const [param, setValue] = useQueryParam('foo', {
    initialValue: 'bar',
    replaceState: false,
  })

  return (
    <DisplayDemo title="useQueryParam">
      <Typography.Paragraph>
        Current value of 'foo' param is <Tag color="green">{param}</Tag><
      /Typography.Paragraph>
      <Input value={param} onChange={(e) => setValue(e.targt.value)} />
    </DisplayDemo>
  );
};

<Router>
  <ExampleComponent />
</Router>

Types

export interface UseQueryParamOptions<TValue extends string> {
    initialValue?: TValue;
    replaceState?: boolean;
}
/**
 * Ease the process of modify the query string in the URL for the current location.
 */
declare const useQueryParam: <TValue extends string>(key: string, options?: UseQueryParamOptions<TValue>) => [TValue, (nextValue?: TValue | undefined) => void];
export default useQueryParam;