Nextjs:更新状态在时间间隔内不工作

Nextjs: update state not work in interval(Nextjs:更新状态在时间间隔内不工作)

本文介绍了Nextjs:更新状态在时间间隔内不工作的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

这是我的状态:

const [time, setTime] = useState(10)

这是我的处理程序:

const runTimer = () => {
    useEffect(() => {
        const interval = setInterval(() => {
            console.log(time)
            if (time > 0) {
                setTime(time - 1)
            } else {
                console.log("End")
            }
        }, 1000);
        return () => clearInterval(interval)
    }, [])
}

我的日志:

9
9
9
9
9
.
.
.

为什么setTime不起作用?

time每1000个延迟增加最多的变量

推荐答案

您传递给useEffect的函数具有closed over该组件第一次呈现时的timer变量。

每次呈现组件时,都会读取状态的当前值,并使用该值创建timer变量。

不过,您并没有访问该变量。您正在访问的variable间隔不会改变,因此每次您访问它时,它仍然是10


将当前值作为参数传递给状态函数,因此请改用当前值。

const Timer = () => {
    const [timer, setTime] = useState(10);
    useEffect(() => {
        const interval = setInterval(() => {
            setTime(
                (currentTime) => {
                    if (currentTime > 0) {
                        return currentTime - 1;
                    } else {
                        console.log(end);
                        clearInterval(interval);
                        return currentTime;
                    }
                }
            );
        }, 1000);
        return () => clearInterval(interval)
    }, [])
    return <p>{timer}</p>
}

这篇关于Nextjs:更新状态在时间间隔内不工作的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:Nextjs:更新状态在时间间隔内不工作