异步处理
const [result, updateResult] = useAsync({});
const update = useCallback(params => updateResult({res: fetchList({...commonParams, ...params})}, handleResult), []);
- result:返回结果
- updateResult:更新函数。如:{userList: fetcher()},userList:存在 result 里面的字段名,fetcher:自己的请求封装函数
- handleResult:处理返回结果函数
将图片 src 地址 改为 base64。
const Base64Image = ({src, ...rest}) => {
const url = useBase64(src);
return <img decoding="async" loading="lazy" {...rest} src={url} />;
};
可取消异步函数
const {cancelablePromise} = useCancelablePromise();
cancelablePromise(asyncFn, delay)
.then(res => {})
.catch(error => {});
- delay:超时中断,默认 true,超时时间 2 分钟
点击区域外部时触发的事件
useClickAway(liRef, e => li.open && itemClick(e, li));
第一个参数为区域元素,第二个为点击区域外部时的回调函数。
useDebounce(fn, (delay = 60));
第一个参数为需要防抖的函数,第二个为防抖时间,默认 60ms。
延迟获取 state
- delay:延迟时间,默认 450ms
const [delayOpen] = useDelayState(open, delay);
是否为第一次加载
const isFirst = useFirstMounted();
定时器
const [count, setCount] = useState(0);
const [stop, setStop] = useState(false);
const delay = 3000;
useInterval(
() => {
setCount(count + 1);
},
stop ? null : delay,
);
第一个参数为回调函数,第二个参数是延迟时间。当 delay 值为 null 或 false 时,会停止回调函数的执行。
上一个 state 值
const prevState = usePrevious(state);
requestAnimationFrame
const [state, setState] = useRaf({});
const state = useScroll(element);
传入监听滚动的元素,默认 window
返回 state 为滚动位置信息。
搜索函数
const [filterTree, setFilterTree] = useSearch(null, str2Dom);
setFilterTree(data, keyword, (fields = 'name'), (exact = false), (idKey = 'id'), (childKey = 'children'));
- data:列表数据
- keyword:搜索值
- fields:搜索字段,字符串或数组。根据属性过滤,默认
name
,设为null
则全局所有属性搜索 - exact:是否为精确匹配,默认是模糊搜索
- idKey:节点唯一标识符
- childKey:子节点属性值
- str2Dom:高亮关键词
状态管理
const [state, update, subscribe, clean] = useStore(name, initState);
input:
- name:事件 key
- initState:初始化值
output:
- state:状态值
- update:更新状态
- subscribe:监听状态
- clean:清除监听
可以自定义状态管理库:
const store = createStore();
const useStore = createContainer(store);
更新
const rerender = useUpdate();
rerender();
初次进入不执行,state 发生变更时执行。
useUpdateEffect(()=>{
...
return ()=>...;
},[state]);
const {width} = useWinResize();
// delay:节流时间
const state = useEleResize(ref, (delay = 250));
获取/设置 render 过程中的 ref。
const data = useCustomRef(0)();