我正在尝试创建一个加载组件,该组件将使用 React 中的 setInterval 每隔 1000 毫秒定期向 div 添加一个句点。我正在尝试使用文档中描述的方法清理 setInterval。
https://reactjs.org/docs/hooks-effect.html#example-using-hooks-1
import React, { useEffect, useState } from 'react'
const Loading = () => {
const [loadingStatus, setLoadingStatus] = useState('.')
const [loop, setLoop] = useState()
useEffect(() => {
setLoop(setInterval(() => {
console.log("loading")
setLoadingStatus(loadingStatus + ".")
}, 1000))
return function cleanup() {
console.log('cleaning up')
clearInterval(loop)
}
}, [])
return (<p>
{`Loading ${loadingStatus}`}
</p>)
}
export default Loading
然而,loadingStatus 变量只更新一次并且即使在组件停止安装之后 setInterval 循环也不会被清除。我必须使用类组件来做这个吗?