React 自定义Hook优化处理搜索筛选问题

React 自定义Hook优化处理搜索筛选问题

在这里插入图片描述
在很多场景下,我们需要通过筛选多个条件来确定自己想要的结果,而这些筛选的条件会作为路由的参数传递给后端,以此获取到对应的数据

清理数据

Record类型

type Record<K extends keyof any, T> = {
    [P in K]: T;
};

Record类型的数据,键的类型取决于K,值的类型取决于T


判断是否为空值

export const isNull = (val: unknown) =>
  val === undefined || val === null || val === "";

export const cleanObject = (obj: Record<string, unknown>) => {
  const result = { ...obj };
  Object.keys(result).forEach((key) => {
    const val = result[key];
    if (isNull(val)) {
      delete result[key];
    }
  });
  return result;
};

自定义Hook

import { useMemo } from "react"
import { URLSearchParamsInit, useSearchParams } from "react-router-dom"
import { cleanObject } from "utils"

export const useUrlQueryParam = <T extends string>(keys: T[]) => {
    const [search, setSearch] = useSearchParams()
    return [
        useMemo(() => {
            return keys.reduce((pre, key) => {
                return { ...pre, [key]: search.get(key) || '' }
            }, {} as { [key in T]: string })
        }, [search]),
        (params: Partial<{ [key in T]: unknown }>) => {
            // Object.fromEntries是将可迭代的对象转为一个新对象
            const o = cleanObject({...Object.fromEntries(search),...params}) as URLSearchParamsInit
            return setSearch(o)
        }
    ] as const
}

解析

  1. 使用reduce拼接一个对象
keys.reduce((pre, key) => {
     return { ...pre, [key]: search.get(key) || '' }
 },{} as { [key in T]: string })
  • 路由中的search参数只能通过search.get(key)进行获取
  • {...pre,[key]: search.get(key) || '' },其效果于Object.asign()是相同的
  1. <T extends string>

T必须要受到string类型的约束,这是因为[key]:search.get(key)

  • 第一个key要求类型必须为"string"、"number"、"symbol" 或 "any"
  • 第二个key则要求类型必须为string
  1. 返回的参数
  • search参数的对象
  • 修改search参数的函数

使用

  1. 确定筛选/搜索的键值

     const [param,setParam] = useUrlQueryParam(['name','personId'])
    

    此处我们传入['name','personId'],意味着之后对参数的修改只能是这两个键

  2. 修改参数

    <Input type="text" placeholder="项目名" value={param.name} onChange={event => {
    	setParam({
    		...param,
    		name:event.target.value
    	})
    }}/>
    
  3. 搭配useEffect副作用函数

    useEffect(() => {
    	...请求数据的异步函数
    },[])
    

    当我们修改search参数之后,组件重新渲染,那么数据将会更新

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值