2020年7月7日星期二

Flutter学习笔记(40)

如需转载,请注明出处:Flutter学习笔记(40)--Timer实现短信验证码获取60s倒计时

先看下效果:

两种需求场景:

1.广告页3s后跳转到首页

2.短信验证码60s倒计时

第一种的话,根据需求我们可以知道,我们想要的效果就是3s结束做出一个动作。

 factory Timer(Duration duration, void callback()) { if (Zone.current == Zone.root) {  // No need to bind the callback. We know that the root's timer will  // be invoked in the root zone.  return Zone.current.createTimer(duration, callback); } return Zone.current  .createTimer(duration, Zone.current.bindCallbackGuarded(callback)); }

 两个参数,第一个参数超时时间,即多久后执行你想要的动作,第二个参数callback回调方法,即超时后你想要执行的动作是什么,比如跳转到首页。

第二种的话就是需要不断的做出倒计时的动作。

 factory Timer.periodic(Duration duration, void callback(Timer timer)) { if (Zone.current == Zone.root) {  // No need to bind the callback. We know that the root's timer will  // be invoked in the root zone.  return Zone.current.createPeriodicTimer(duration, callback); } var boundCallback = Zone.current.bindUnaryCallbackGuarded<Timer>(callback); return Zone.current.createPeriodicTimer(duration, boundCallback); }

这种调用方式和上面的方式的区别是:第一种只会回调一次,就是超时时间到了之后执行callback回调方法,而Timer.periodic调用方式是循环不断的调用,比如说通过这种方式,你设置的超时时间是1s的话,那就会每隔1s调用一次callback的回调方法,也就是通过这种方式来实现我们的短信验证码60s倒计时获取。

看下具体用法吧:

 Timer _timer; int _timeCount = 60;

触发事件:

onTap: () {  _startTimer();},

 

处理方法:

 void _startTimer() { ToastUtil.showTips('短信验证码已发送,请注意查收'); _timer = Timer.periodic(Duration(seconds: 1), (Timer timer) => {  setState(() {  if(_timeCount <= 0){   _autoCodeText = '重新获取';   _timer.cancel();   _timeCount = 60;  }else {   _timeCount -= 1;   _autoCodeText = "$_timeCount" + 's';  }  }) }); }

 

Flutter学习笔记(40)易佰haofang知无不言亚马逊干货-绝对干货 (知道大家积分有限,没有设置太高)如何成为速卖通好卖家?优势有哪些?亚马逊卖家该不该、如何获取亚马逊直评?珠海长隆报团多少钱珠海长隆报团旅游多少钱珠海长隆报团旅游多少钱

没有评论:

发表评论