美文网首页Angular.js专场Android知识程序员
Ionic Angular 实现验证码倒计时功能

Ionic Angular 实现验证码倒计时功能

作者: SmartSean | 来源:发表于2017-04-18 18:18 被阅读246次

    前段时间分享了 Android 原生实现验证码倒计时,地址是这里,现在公司使用 Ionic 开发的 App 也要实现类似的功能,现在也记录下来,供大家参考:

    效果图:

    gif.gif

    正文

    首先介绍下与本文相关的概念 $interval

    $interval 是 window.setInterval 的 Angular 包装形式,函数如果在没有被取消的时候会无限执行。(取消使用 cancel(promise) )

    用法:

    $interval(fn,delay,[count],[invokeApply],[Pass]);
    

    参数说明:

    • fn : 无限执行的函数 必须参数,必传
    • delay : 每次调用的间隔毫秒数值 必须参数,必传
    • count : 循环次数的数值,如果没设置,则无限制循环 非必须参数,可不传
    • invokeApply : 如果设置为false,则避开脏值检查,否则将调用$apply 非必须参数,可不传
    • Pass : 函数的附加参数 非必须参数,可不传

    方法:

    • cancel(promise)
      • promise:$interval函数的返回值。

    具体实现

      $scope.description = "获取验证码";
    
      var timerHandler = null;
    
      /**
       * 倒计时
       * @param time 控制循环次数
       */
      var countDown = function (second,time) {
        timerHandler = $interval(function () {
          if (second <= 0) {
            $interval.cancel(timerHandler);
            second = 59;
            $scope.description = "获取验证码";
          } else {
            $scope.description = second + "s 后可重发";
            second--;
          }
        }, 1000, time)
      }
    

    调用

    countDown(59,60);
    

    最后别忘了注入 $interval 。

    相关文章

      网友评论

        本文标题:Ionic Angular 实现验证码倒计时功能

        本文链接:https://www.haomeiwen.com/subject/yykqzttx.html