1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | import { useEffect, useRef } from 'react' ; const defaultCompare = (prev, next) => prev === next; export const useWatch = ( callback, value, { initialValue = '' , compare = defaultCompare } = {}, ) => { const prevValue = useRef(initialValue); const safeEffects = useRef([]); const prev = prevValue.current; if (!compare(prev, value)) { const safeEffect = callback === null || callback === void 0 ? void 0 : callback(prev); if ( typeof safeEffect === 'function' ) { safeEffects.current.push(safeEffect); } prevValue.current = value; } useEffect(() => { safeEffects.current.forEach((safeEffect) => safeEffect()); safeEffects.current = []; }); }; export default useWatch; |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗
2020-07-14 webpack源码讲解教程
2020-07-14 Vue.js源码解析教程(某课网)(含Vue3.0源码分析)
2020-07-14 encodeURI()和encodeURIComponent() 区别