实用的 useSearchParam 钩子函数

why?

在 React 开发中,在 search 中获取 param 数据,十分常用,但是似乎但是每次都要手动的使用URLSearchParams 构造函数然后获取 params, 这其实不符合 React 的钩子函数的开发范式,可以将 param 的获取封装到自定义 hooks 中每次使用的时候,字节调用钩子函数即可。

封装一个通用的钩子函数需要考虑哪些问题?

以 react-use 为例,需要考虑这些问题

  • 当前环境,因为 react 有服务端渲染,考虑 nodejs 环境
  • 通过 URLSearchParams 获取 search params
  • 同时需要监听路由的变化:popstate/pushstate/replacestate 这些变化

实现

ts 复制代码
import { useEffect, useState } from 'react';
import { isBrowser, off, on } from './misc/util';

const getValue = (search: string, param: string) => new URLSearchParams(search).get(param);

export type UseQueryParam = (param: string) => string | null;

const useSearchParam: UseQueryParam = (param) => {
  const location = window.location;
  const [value, setValue] = useState<string | null>(() => getValue(location.search, param));

  useEffect(() => {
    const onChange = () => {
      setValue(getValue(location.search, param));
    };

    on(window, 'popstate', onChange);
    on(window, 'pushstate', onChange);
    on(window, 'replacestate', onChange);

    return () => {
      off(window, 'popstate', onChange);
      off(window, 'pushstate', onChange);
      off(window, 'replacestate', onChange);
    };
  }, []);

  return value;
};

const useSearchParamServer = () => null;

export default isBrowser ? useSearchParam : useSearchParamServer;
  • 名字需要以 use 开头。
  • getValue 函数封装是需要传入 search 和 需要查找的目标 param 封装在函里面计算目标数据。
  • 定义状态保存目标 param 的状态,和更新 param 的函数。
  • 返回值是 value, 也就是查询的 param 的值。
  • 由于路由可能发生变化, 在 useEffect 中完成对实践的监听,并使用 getValue 重新计算。

小结

写这篇文章目的是在一些通用的,和符合规范的方面,尽量与规范靠齐。同时学会自己封装一个通用的函数,钩子函数。加速自己的开发效率。

相关推荐
AI3D_WebEngineer1 分钟前
企业级业务平台项目设计、架构、业务全解之组件库篇
前端·javascript·vue
charlie11451419127 分钟前
从零开始理解 CSS:让网页“活”起来的语言2
前端·css·笔记·学习·选择器·样式表·原生
浪裡遊38 分钟前
Next.js路由系统
开发语言·前端·javascript·react.js·node.js·js
mapbar_front41 分钟前
职场中的顶级能力—服务意识
前端
尽兴-1 小时前
[特殊字符] 微前端部署实战:Nginx 配置 HTTPS 与 CORS 跨域解决方案(示例版)
前端·nginx·https·跨域·cors·chrom
JIngJaneIL2 小时前
助农惠农服务平台|助农服务系统|基于SprinBoot+vue的助农服务系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·助农惠农服务平台
云外天ノ☼2 小时前
待办事项全栈实现:Vue3 + Node.js (Koa) + MySQL深度整合,构建生产级任务管理系统的技术实践
前端·数据库·vue.js·mysql·vue3·koa·jwt认证
gihigo19982 小时前
使用JavaScript和Node.js构建简单的RESTful API
javascript·node.js·restful
一位搞嵌入式的 genius2 小时前
前端实战开发(三):Vue+Pinia中三大核心问题解决方案!!!
前端·javascript·vue.js·前端实战
塞纳河畔的歌2 小时前
保姆级教程 | 麒麟系统安装Edge浏览器
前端·edge