首页 文章

React组件中的setInterval和热重载(Webpack)

提问于
浏览
0

我想在React组件中重复调用一个函数,从它安装的时候开始,直到它卸载,并使它与webpack HMR(热重载)一起工作 .

最简单的方法是在ReactJS docs中建议的componentDidMount中设置一个间隔:[1]:https://facebook.github.io/react/docs/component-specs.html#mounting-componentdidmount

componentDidMount () {
  const number = Math.floor(Math.random() * 1000) + 1
  setInterval(() => console.log('Component ' + number.toString()), 5000)
}

我已搜索但无法找到解决方案来清除间隔之前webpack HMR为我们更新的组件调用componentDidMount . 这意味着每次模块热重新加载时我们都有一个新的间隔 .

注意:在Webpack重新绑定之前不会调用 componentWillUnmount

更新:当正确设置HMR时,重新绑定应调用 componentWillUnmount

使用webpack HMR实现重复延迟函数调用的最佳方法是什么?

1 回答

相关问题