react 使用自定义hooks封装不会反复创建的定时器(setInterval)

react 需要通过useRef来创建定时器,否则清不干净,每次去写太麻烦,简单封装一下,直接代码

自定义hooks

import { useRef, useState } from 'react';

const useTimer = (step = 1) => {
  const timer = useRef(null)
  const [ num, setNum ] = useState(0)
  const start = () => {
    const timeout = setInterval(() => {
      setNum((num) => num + 1) // 不能写为setNum(num + 1);就不会更新num 的值
    }, step * 1000)
    timer.current = timeout
  }
  const clear = () => {
    setNum(0)
    clearInterval(timer.current)
  }
  return {
    num,
    start,
    clear
  }
}
export default useTimer

在组件中使用

import React, { useEffect, useState } from 'react';
import { Steps } from 'antd';
import useTimer from '@/hooks/timer'
const { Step } = Steps;
export default function Home() {
  const [current, setcurrent] = useState(0);
  const { num, start, clear } = useTimer(2)
  useEffect(() => {
	start() // 启动定时器
  }, []);
  const changeStep = (num: number) => {
    setcurrent(num)
    clear() // 清除定时器
    start() // 重新启动
  }
  return (
   <div className='container'>
     <div className="box">
        <div className="time-box">
          已浏览当前模块:{num}</div>
        <Steps className='steps' size="small" current={current} direction="vertical">
          <Step onClick={ () => {changeStep(0)} } title="广交会" />
          <Step onClick={ () => {changeStep(1)} } title="天津智能大会" />
          <Step onClick={ () => {changeStep(2)} } title="游密云" />
        </Steps>
     </div>
   </div>
  );
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值