React实现按钮控制倒计时

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<script src="https://cdn.bootcss.com/react/15.4.2/react.min.js"></script>
<script src="https://cdn.bootcss.com/react/15.4.2/react-dom.min.js"></script>
<script
src="https://cdn.bootcss.com/babel-standalone/6.22.1/babel.min.js"></script>
</head>
<body>
<div id="example"></div>
<script type="text/babel">
    var LikeButton = React.createClass({
      getInitialState: function(){
        return {
          count: 30,
          liked: true,
          flag:true,
          stop:true,
        };
      },
      handleClick: function(){
        clearInterval(this.timer);
        this.state.stop=false;
        this.state.flag = !this.state.flag;


        if (this.state.flag) {
          this.setState({
                liked:true,
                count: this.state.count
              });
      }else{
        if(this.state.liked){
          this.timer = setInterval(function () {
            var count = this.state.count;
            this.state.liked = false;
            count -= 1;
            if (count < 1) {
              this.setState({
                liked: true
              });
              count = 30;
        clearInterval(this.timer);
            }
            this.setState({
              count: count
            });
          }.bind(this), 1000);
        }
      }
        
      },
      render: function(){


          var text = this.state.stop ? '点击开始计时' : this.state.count + '秒';
        return(
          <p>
            <button onClick={this.handleClick}>{text}</button>
          </p>
        )}
    });




    ReactDOM.render(
      <LikeButton />,
      document.getElementById('example')
    );
    </script>
</body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值