useEffect清除定时器

发布于 2022-09-11 23:11:59 字数 923 浏览 14 评论 0

useRef保存值,用来清除定时器;但是在清除定时器时写的useEffect第二个参数传递问题导致无法清除,不传参数时可以清除,传递反而不能清除,请问为什么?
image.png


import React, { useState, useRef, useEffect } from 'react';

// useRef保存timer
export default function App(props) {
  const [count, setCount] = useState(0);
  const timerRef = useRef();
  console.log(timerRef)

  useEffect(() => {
    timerRef.current = setInterval(() => {
      if (count < 2) {
        setCount(count => count + 1);
      }
    }, 10);
    console.log(timerRef.current, '1 effect') // 2 "1 effect"
  }, []);

  useEffect(() => {
    console.log(timerRef.current, '2 effect'); // 2 "2 effect"
    if (count >= 2) {
      clearInterval(timerRef.current)
    }
  }) //为什么第二个参数传入[],反而不能清除定时器呢?
  // }, [])

  return (
    <div>
      <div>数值:{count}</div>
    </div>
  );

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

随风而去 2022-09-18 23:11:59

执行1次, count不满足清除的条件,不能清除,需要传入[count],生效。感谢@jokester

美人骨 2022-09-18 23:11:59

感觉你回答的太简单了,我忍不住插个嘴。

useEffect 第二个参数是他的依赖值数组,可以根据依赖变动执行响应 effect。文档显示,有三种情况:

1. 不传

表示每轮组件渲染完成后执行,也就是渲染一次执行一次。有点像 componentDidUpdate

2. 传空数组 []

表示没有任何依赖,永远都只执行一次。有点像 componentDidMount

3. 传入一个依赖数组 [props.haha]

表示依赖发生变化,渲染后执行。还是像 componentDidUpdate 只是设置了门槛

所以想要清除定时器生效就要依赖 count,在变成大于 2 时执行;除此之外,我认为还要在组件卸载的时候执行,因为组件卸载可能先于 count >= 2。所以还要加一句:

  useEffect(() => {
    timerRef.current = setInterval(() => {
      if (count < 2) {
        setCount(count => count + 1);
      }
    }, 10);
    console.log(timerRef.current, '1 effect') // 2 "1 effect"
    return () => {
        timerRef.current && clearInterval(timerRef.current)
    }
  }, []);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文