Ionic + Angular.js实现验证码倒计时功能的方法
程序员文章站
2022-04-10 11:38:54
前言
之前跟大家分享了关于 android 原生实现验证码倒计时,地址是,现在公司使用 ionic 开发的 app 也要实现类似的功能,现在也记录下来,供大家参考:
效...
前言
之前跟大家分享了关于 android 原生实现验证码倒计时,地址是,现在公司使用 ionic 开发的 app 也要实现类似的功能,现在也记录下来,供大家参考:
效果图:
正文
首先介绍下与本文相关的概念 $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
。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对的支持。
上一篇: 原生JS+HTML5实现跟随鼠标一起流动的粒子动画效果
下一篇: 跟老外PK英语