首页 > 解决方案 > 在哪里调用 setInterval 反应

问题描述

我是新来的反应。我想使用 setState 和 setInterval 创建一个计数器。我不想将 react.dom 渲染放在一个间隔中,因为我知道这不是一个好习惯。这是我到目前为止的努力:

class Counter extends React.Component {
  state = {
    counter: 0
  }
  increment = () => {
    setInterval(() => {
      this.setState({
        counter: this.state.counter+1});
    }, 1000);
   
  };
  
  render() {
    return <div>
    <p>{this.state.counter}</p>
    </div>;
  }
}


const el = <Counter />; 
ReactDOM.render(
  el, document.getElementById('root')
);

我也尝试过这种方式:

class Counter extends React.Component {
  state = {
    counter: 0
  }
  increment = () => {
    this.setState({
     counter: this.state.counter+1});
  };
  
  render() {
    return <div>
    <p>{this.state.counter}</p>
    </div>;
  }
}

setInterval(Counter.increment, 100)

const el = <Counter />; 
ReactDOM.render(
  el, document.getElementById('root')
);

他们都没有工作。问题是什么?

标签: reactjs

解决方案


您没有调用该increment函数。你必须在里面调用它componentDidMount()

class Counter extends React.Component {
  state = {
    counter: 0
  }
  increment = () => {
    setInterval(() => {
      this.setState({
        counter: this.state.counter+1});
    }, 1000);
   
  };
  
  componentDidMount(){
    this.increment();
  }
  
  render() {
    return <div>
    <p>{this.state.counter}</p>
    </div>;
  }
}

ReactDOM.render(<Counter/>, document.getElementById("root"))
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>

<div id="root"></div>


推荐阅读