React中Hooks封装倒计时60S

使用hooks对倒计时进行封装(TS版),结合useStateuseEffectuseRef 以及定时器setInterval

  1. useState对count进行数据初始化,后边结合setcount()方法对count进行修改
  2. useRef是作为定时器的一个Id,便于后面清除定时器
  3. 第一次的useEffect是作为定时器的启动,传入一个空数组【】,不依赖任何项,只调用一次
  4. 第二次的useEffect是作为清除定时器使用,依赖于count的变化,故传入一个包含count的数组
import {useState,useEffect,useRef} from 'react'

export default function useTimes(start:number) {
    const [count,setcount] =useState(start)
    const timerRef=useRef<NodeJS.Timer>()
        
    useEffect(()=>{
        timerRef.current=setInterval(()=>{
            setcount(c=>c-1)
        },1000)
        //清除副作用
        return ()=>{
            clearInterval(timerRef.current)
        }
    },[])
    useEffect(()=>{
        if(count===0){
            clearInterval(timerRef.current)
        }
    },[count])
    return count
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值