首页 > 解决方案 > Preact setState hook 在 setInterval 中不起作用

问题描述

CodeSandbox
试图useStatesetInterval一个preact/hook. 这不起作用,看起来永远迭代它正在执行以前的调用堆栈(?)。有人可以帮助我理解并帮助我修复这个片段吗?

import {h} from 'preact';
import {useState} from 'preact/hooks'
const interests = [
  {name: 'the future',},
  {name: 'architecture',},
  {name: 'my work',},
  {name: 'your work',},
  {name: 'collaboration',},
  {name: 'dank memes',},
  {name: 'OOP vs. Functional',},
  {name: 'design',},
  {name: 'guitar',},
  {name: 'inspirational people',},
  {name: 'love',},
  {name: 'travel',},
  {name: 'singularity',},
  {name: 'creativity',},
  {name: 'mixed, virtual, augmented reality',},
  {name: 'art',},
  {name: 'imagination',},
  {name: 'problem solving',},
  {name: 'space',},
  {name: 'cooking',},
  {name: 'FOMO',},
  {name: 'ontological design',},
  {name: 'flow state',},
  {name: 'foreign languages',},
  {name: 'streaming on the internet',},
  {name: 'video games',},
  {name: 'coffee',},
  {name: 'crypto currency',},
  {name: 'javascript fatigue',},
  {name: 'framework wars',},
  {name: 'blockchain',},
  {name: 'smart contracts',},
  {name: 'just emailing me'},
  {name: 'ethereum'},
  {name: 'university'},
  {name: 'engineering software'},
];


const RunningHeader = () => {
  const [count, setCount] = useState(0);
  setInterval(() => {setCount(c => c + 1)}, 1000);
  return (
    <header>
      <p>{interests[count].name}</p>
    </header>
)}

export {RunningHeader};

标签: asynchronousstatesetintervalreact-hookspreact

解决方案


useEffect没有依赖[]项将充当 componentDidMount 来挂载我们的间隔,我们可以返回一个函数来在卸载时调用,我们应该在卸载时清除我们的间隔以避免内存泄漏。

useEffect(() => {
  const id = setInterval(() => {
    setCount(c => c + 1);
  }, 1000);
  return () => clearInterval(id);
}, []);

推荐阅读