当前位置:   article > 正文

React 中 5 个好用的 Hook

react常用的五种hook

大厂技术  高级前端  Node进阶

点击上方 程序员成长指北,关注公众号

回复1,加入高级Node交流群

作者:晚安啦
https://juejin.cn/post/7223325932357795895

React.js 目前是前端开发人员十分流行的 JavaScript 库。它由 Facebook 发明,但作为开源项目提供给世界各地的开发人员和企业使用。

React 真正改变了我们构建单页面应用程序的方式,其中最大的特点之一是函数组件的应用。Hooks 是19年推出的,使我们能够在处理状态时使用函数组件而不是基于类的组件。除了内置的 hooks 外,React 还提供了实现自定义 hooks 的方法。

这里是一些我最喜欢的自定义 hooks 实现,您也可以在自己的应用程序和项目中使用。

1. useTimeout

使用这个hooks,我们可以使用声明式方法来实现setTimeout。首先,我们创建一个自定义hooks子,其中包含回调函数和延迟参数。然后,我们使用useRef hooks为回调函数创建一个引用。最后,我们两次使用useEffect,一次用于记住上次的回调函数,一次用于设置超时并清理。

以下是一个计时器的实现示例:

  1. import {useEffect} from 'react'
  2. const useTimeout = (callback,delay)=>{
  3.   const savedCallback=React.useRef();
  4.   useEffect(()=>{
  5.       savedCallback.current=callback
  6.   },[callback]);
  7.   
  8.   useEffect(()=>{
  9.       const tick=()=>{
  10.           savedCallback.current();
  11.       }
  12.       if(delay!==null){
  13.           let id=setTimeout(tick,delay);
  14.           return ()=>clearTimeout(id);
  15.       }
  16.   },[delay])
  17. }

2. useInterval

如果你想以声明性的方式实现setInterval,你可以使用名为useInterval的hooks。

首先,我们需要创建一个自定义hooks,接受一个回调函数和一个延迟时间作为参数。然后,我们使用useRef为回调函数创建一个ref。最后,我们使用useEffect来记住最新的回调函数,并设置和清除间隔。

该示例展示了自定义ResourceCounter的实现。

  1. import {useRef,useEffect} from 'react';
  2. const useInterval = (callback,delay)=>{
  3.   const savedCallback=React.useRef();
  4.   useEffect(()=>{
  5.       savedCallback.current=callback
  6.   },[callback]);
  7.   
  8.   useEffect(()=>{
  9.       const tick=()=>{
  10.           savedCallback.current();
  11.       }
  12.       if(delay!==null){
  13.           let id=setInterval(tick,delay);
  14.           return ()=>clearInterval(id);
  15.       }
  16.   },[delay])
  17. }

3. usePrevious

这是另一个可以在我们的应用程序中使用的很棒的自定义钩子。通过它,我们可以存储props或先前的状态。首先,我们创建一个接受值的自定义钩子。然后,我们使用useRef钩子为该值创建一个ref。最后,我们使用useEffect来记住最新的值。这个示例展示了一个计数器的实现。

  1. import {useRef,useEffect} from 'react';
  2. const usePrevious=value=>{
  3.     const ref=useRef();
  4.     useEffect(()=>{
  5.         ref.current=value
  6.     }, [])
  7.     return ref.current;
  8. }

4. useClickInside

如果你需要处理包装组件内部的点击事件处理,那么useClickInside hooks就是适合你的选择。首先,我们创建一个自定义hooks,它接受一个ref和一个回调函数来处理点击事件。然后,我们使用useEffect来附加和清除点击事件。最后,我们使用useRef为需要被点击的组件创建一个ref,并将其传递给useClickInside hooks。

  1. import {useEffect} from 'react';
  2. const useClickInside = (ref,callback)=>{
  3.     const handleClick=e=>{
  4.         if(ref.current&&ref.current.contains(e.target)){
  5.             callback();
  6.         }
  7.     };
  8.     useEffect(()=>{
  9.         document.addEventListener('click',handleClick);
  10.         return ()=>{
  11.             document.removeEventListener('click',handleClick);
  12.         }
  13.     }, [])
  14. }

5. useClickOutside

useClickOutside hooks与useClickInside hooks非常相似,但它处理的是在包装组件外部的点击,而不是内部的点击。因此,我们再次创建一个自定义hooks,它接受一个ref和一个回调函数来处理点击事件。然后,我们使用useEffect来附加和清除点击事件。最后,我们使用useRef为组件创建一个ref,并将其传递给useClickOutside hooks。

  1. import {useEffect}from 'react';
  2. const useClickOutside = (ref,callback)=>{
  3.     const handleClick=e=>{
  4.         if(ref.current&&!ref.current.contains(e.target)){
  5.             callback();
  6.         }
  7.     };
  8.     useEffect(()=>{
  9.         document.addEventListener('click', handleClick);
  10.         return ()=>{
  11.           document.removeEventListener('click', handleClick);
  12.         }
  13.     }, [])
  14. }

6. 参考

8 Awesome React Hooks -- Simon Holdorf  
https://link.juejin.cn/?target=https%3A%2F%2Fmedium.com%2Fbetter-programming%2F8-awesome-react-hooks-2cb31aed4f3d

—— The  End ——

Node 社群

 
 

我组建了一个氛围特别好的 Node.js 社群,里面有很多 Node.js小伙伴,如果你对Node.js学习感兴趣的话(后续有计划也可以),我们可以一起进行Node.js相关的交流、学习、共建。下方加 考拉 好友回复「Node」即可。

7c783cd765ed67f2a4db824187da2895.png

“分享、点赞、在看” 支持一下
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/411782
推荐阅读
相关标签
  

闽ICP备14008679号