react自定义hooks解决内存泄漏
销毁组件时,报警告:
解决:
utils/hooks.ts
export const useFetchState = (...props: any) => { const focus = useRef<any>(null); const [state, setState] = useState(...props); useEffect(() => { focus.current = true; return () => (focus.current = false); }, []); const setFetchState = useCallback((...params) => { focus.current && setState(...params); }, []); return [state, setFetchState]; }
组件中使用useFetchState替代useState
import { useFetchState } from '@/utils/hooks' // const [yearOption, setYearOption] = useState<any[]>([]) // 学年options // const [monthOption, setMonthOption] = useState<any[]>([]) // 月options const [yearOption, setYearOption] = useFetchState([]) // 学年options const [monthOption, setMonthOption] = useFetchState([]) // 月options
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· 地球OL攻略 —— 某应届生求职总结
2020-04-26 git从主分支上拉取新分支以及提交代码、合并到主分支
2020-04-26 前端项目初始化