欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Ionic + Angular.js实现验证码倒计时功能的方法

程序员文章站 2022-04-10 11:38:54
前言 之前跟大家分享了关于 android 原生实现验证码倒计时,地址是,现在公司使用 ionic 开发的 app 也要实现类似的功能,现在也记录下来,供大家参考: 效...

前言

之前跟大家分享了关于 android 原生实现验证码倒计时,地址是,现在公司使用 ionic 开发的 app 也要实现类似的功能,现在也记录下来,供大家参考:

效果图:

Ionic + Angular.js实现验证码倒计时功能的方法

正文

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

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

用法:

$interval(fn,delay,[count],[invokeapply],[pass]);

参数说明:

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

方法:

1、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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对的支持。