search params 请求参数的获取与更新
Updated:
摘要(由llm生成)
React Router 的 `useSearchParams` Hook 提供了一个内建的 API,允许直接获取查询参数的值,比如 `.get()`, `.set()`, `.append()` 等。该 hook 可以帮助开发者轻松地处理 URL 中的 query parameters。 使用 `qs` 库和 `window.location.search` 的方法也是可以实现解析 query parameters 的效果。但需要注意的是,`qs.parse(window.location.search)` 会将带有问号的字符串直接返回,而不对其进行处理。在正确的情况下,将需要手动去掉问号,以得到期望的结果。 React Router 的 `useSearchParams` Hook 和 `qs` 库结合使用,可以帮助开发者更容易地管理 URL 中的 query parameters。
react router useSearchParams
useSearchParams | React Router
interface URLSearchParams { /** Appends a specified key/value pair as a new search parameter. */ append(name: string, value: string): void; /** Deletes the given search parameter, and its associated value, from the list of all search parameters. */ delete(name: string): void; /** Returns the first value associated to the given search parameter. */ get(name: string): string | null; /** Returns all the values association with a given search parameter. */ getAll(name: string): string[]; /** Returns a Boolean indicating if such a search parameter exists. */ has(name: string): boolean; /** Sets the value associated to a given search parameter to the given value. If there were several values, delete the others. */ set(name: string, value: string): void; sort(): void; /** Returns a string containing a query string suitable for use in a URL. Does not include the question mark. */ toString(): string; forEach(callbackfn: (value: string, key: string, parent: URLSearchParams) => void, thisArg?: any): void;}
它提供了内建的 API,允许直接获取查询参数的值,比如 .get()
, .set()
, .append()
等。
const [queryParams, setQueryParams] = useSearchParams(); console.log('%c Line:52 🍿 queryParams', 'color:#33a5ff', queryParams.get('medicalRecordID'));
qs + window.location
GitHub - ljharb/qs: A querystring parser with nesting support
data:image/s3,"s3://crabby-images/c3e40/c3e4022153a07f3ebe64d52f50bcacb4c04cff14" alt="image.png"
使用 window.location.search 获取到请求参数对应的字符串(需要注意的是:字符串是带有?的)
然后使用 qs.parse 方法来解析查询字符串
案例:localhost?medicalRecordID=1
错误使用:
const getQueryParam = (): QueryParams => { // use qs to parse the query params const queryParams: QueryParams = qs.parse(window.location.search); return queryParams;};
data:image/s3,"s3://crabby-images/18098/18098bda2fb3d55bdb30130521bd9a37f74298b8" alt=""
正确使用:
const getQueryParam = (): QueryParams => { // use qs to parse the query params const queryParams: QueryParams = qs.parse(window.location.search.slice(1)); return queryParams;};
data:image/s3,"s3://crabby-images/35e2c/35e2c015f4332fe92e8cc61675af9f6f2d4696d3" alt="image.png"
感谢阅读到这里,期待收到更多的反馈
欢迎关注公众号
kazoottt
data:image/s3,"s3://crabby-images/b18b2/b18b2615393ce4566fb4310b9ddcfb613b888afb" alt="公众号二维码"