Flutter获取验证码倒计时按钮

在Flutter中,有一个定时器类Timer,使用方法:

Timer timer = new Timer(new Duration(milliseconds: 60), (){
        //倒计时结束执行
      });

上面代码就是执行一个定时器,60秒后执行回调方法。但是无法获取倒计时的进度。所以我们可以创建一个周期性的Timer:

Timer = countDownTimer = new Timer.periodic(new Duration(seconds: 1), (timer){
        print(timer.tick);
      });

上面是一个按周期执行的timer,每隔1秒钟执行一次,所以我们可以利用这个来写倒计时按钮。

				String yzmText="获取验证码";
                  new OutlineButton(
                    onPressed: yzmText=="获取验证码"?yzmGet:null,
                    padding: EdgeInsets.only(top: 0),
                    borderSide: new BorderSide(color: mainGreenColor),
                    highlightedBorderColor: mainGreenColor,
                    child: new Text(yzmText),
                    textColor: mainGreenColor,
                  ),

首先定义一个按钮显示的文本的变量yzmText,zai onPressed中根据yzmText是否为"获取验证码"判断是否可点击,可点击的话执行yzmGet方法:

	///获取验证码
  Timer countDownTimer;
  yzmGet() {
    countDownTimer?.cancel();//如果已存在先取消置空
    countDownTimer = null;
      countDownTimer = new Timer.periodic(new Duration(seconds: 1), (t){
        setState(() {
          if(60-t.tick>0){//60-t.tick代表剩余秒数,如果大于0,设置yzmText为剩余秒数,否则重置yzmText,关闭countTimer
            yzmText = "${60-t.tick}秒";
          }else{
            yzmText = '获取验证码';
            countDownTimer.cancel();
            countDownTimer = null;
          }
        });
      });
  }

最后别忘记在dispose释放timer:

@override
    void dispose() {
    // TODO: implement dispose
    countDownTimer?.cancel();
    countDownTimer = null;
    super.dispose();

  }

最后的最后:

欢迎各位同学一起学习flutter,群号:187670882
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值