每天一个hooks学习之useUnmount
引言
useUnmount,组件卸载时执行的 Hook,比如组件卸载时,需要清除定时器或者相关的监听,就可以使用useUnmount。
🦌来看看效果
可以看到,只有在子组件销毁时时,useUnmount才执行了。
🐿源码实现
const useUnmount = (fn: () => void) => { const fnRef = useRef(fn); fnRef.current = fn; useEffect(() => () => fn?.(), []); };
🐬完整demo源码
import { useEffect, useRef, useState } from "react"; // 自定义useUnmount hooks const useUnmount = (fn: () => void) => { const fnRef = useRef(fn); fnRef.current = fn; useEffect(() => () => fn?.(), []); }; const Child = () => { useUnmount(() => { console.log("子组件销毁了"); }); return <div>我是子组件</div>; }; const UseUnmountDemo = () => { const [showChild, setShowChild] = useState(true); return ( <> {showChild && <Child />} <button onClick={() => setShowChild(!showChild)}>显示销毁子组件</button>; </> ); }; export default UseUnmountDemo;
🍓参考
有兴趣的小伙伴可以去看,react-use 和 ahooks 的源码,学习前辈们优雅的代码
以上就是每天一个hooks学习之useUnmount的详细内容,更多关于hooks useUnmount的资料请关注脚本之家其它相关文章!
相关文章
react router4+redux实现路由权限控制的方法
本篇文章主要介绍了react router4+redux实现路由权限控制的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-05-05在React中写一个Animation组件为组件进入和离开加上动画/过度效果
这篇文章主要介绍了在React中写一个Animation组件为组件进入和离开加上动画/过度效果,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2019-06-06React报错之Parameter event implicitly has a
这篇文章主要为大家介绍了React报错之Parameter event implicitly has an any type,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-08-08react-native 封装选择弹出框示例(试用ios&android)
本篇文章主要介绍了react-native 封装选择弹出框示例(试用ios&android),具有一定的参考价值,有兴趣的可以了解一下2017-07-07使用react-router4.0实现重定向和404功能的方法
本篇文章主要介绍了使用react-router4.0实现重定向和404功能的方法,具有一定的参考价值,有兴趣的可以了解一下2017-08-08React Router中Link和NavLink的学习心得总结
这篇文章主要介绍了React Router中Link和NavLink的学习心得总结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-12-12React-Hooks之useImperativeHandler使用介绍
这篇文章主要为大家介绍了React-Hooks之useImperativeHandler使用介绍,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-07-07
最新评论