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


Posted in Javascript onJune 12, 2017

前言

之前跟大家分享了关于 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

总结

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

Javascript 相关文章推荐
greybox——不开新窗口看新的网页
Feb 20 Javascript
才发现的超链接js导致网页中GIF动画停止的解决方法
Nov 02 Javascript
JQuery 小练习(实例代码)
Aug 07 Javascript
Javascript基础教程之数据类型转换
Jan 18 Javascript
深入理解JavaScript系列(27):设计模式之建造者模式详解
Mar 03 Javascript
TypeOf这些知识点你了解吗
Feb 21 Javascript
下雪了 javascript实现雪花飞舞
Aug 02 Javascript
vue.js内置组件之keep-alive组件使用
Jul 10 Javascript
Vue-不允许嵌套式的渲染方法
Sep 13 Javascript
微信小程序websocket实现即时聊天功能
May 21 Javascript
Vue中的组件及路由使用实例代码详解
May 22 Javascript
extjs图形绘制之饼图实现方法分析
Mar 06 Javascript
微信小程序 实现点击添加移除class
Jun 12 #Javascript
JavaScript该如何学习 怎样轻松学习JavaScript
Jun 12 #Javascript
微信小程序实现缓存根据不同的id来进行设置和读取缓存
Jun 12 #Javascript
利用Jasmine对Angular进行单元测试的方法详解
Jun 12 #Javascript
原JS实现banner图的常用功能
Jun 12 #Javascript
手把手搭建安装基于windows的Vue.js运行环境
Jun 12 #Javascript
JS获取鼠标坐标并且根据鼠标位置不同弹出不同内容
Jun 12 #Javascript
You might like
无JS,完全php面向过程数据分页实现代码
2012/08/27 PHP
JS异常处理try..catch语句的作用和实例
2014/05/05 PHP
php集成环境xampp中apache无法启动问题解决方案
2014/11/18 PHP
解决在Laravel 中处理OPTIONS请求的问题
2019/10/11 PHP
laravel 5.3 单用户登录简单实现方法
2019/10/14 PHP
javascript实现unicode和字符的互相转换
2007/07/18 Javascript
javascript中有趣的反柯里化深入分析
2012/12/05 Javascript
jquery重新播放css动画所遇问题解决
2013/08/21 Javascript
实用的Jquery选项卡TAB示例代码
2013/08/28 Javascript
JS 获取滚动条高度示例代码
2013/10/24 Javascript
js jquery ajax的几种用法总结(及优缺点介绍)
2014/01/28 Javascript
js判断当前浏览器类型,判断IE浏览器方法
2014/06/02 Javascript
jquery中键盘事件小结
2016/02/24 Javascript
js获取元素的标签名实现方法
2016/10/08 Javascript
基于BootStrap栅格栏系统完成网站底部版权信息区
2016/12/23 Javascript
Bootstrap中datetimepicker使用小结
2016/12/28 Javascript
nodejs调取微信收货地址的方法
2017/12/20 NodeJs
Angular 项目实现国际化的方法
2018/01/08 Javascript
js和jQuery以及easyui实现对下拉框的指定赋值方法
2018/01/23 jQuery
Python进程通信之匿名管道实例讲解
2015/04/11 Python
Python多线程实现同步的四种方式
2017/05/02 Python
Python简单生成随机姓名的方法示例
2017/12/27 Python
Django rest framework基本介绍与代码示例
2018/01/26 Python
解决pandas read_csv 读取中文列标题文件报错的问题
2018/06/15 Python
Python装饰器模式定义与用法分析
2018/08/06 Python
Python判断telnet通不通的实例
2019/01/26 Python
Pyqt清空某一个QTreeewidgetItem下的所有分支方法
2019/06/17 Python
pyqt5 实现在别的窗口弹出进度条
2019/06/18 Python
pycharm如何设置官方中文(如何汉化)
2020/12/29 Python
python用opencv 图像傅里叶变换
2021/01/04 Python
机关搬迁方案
2014/05/18 职场文书
关于读书的演讲稿300字
2014/08/27 职场文书
学习张林森心得体会
2014/09/10 职场文书
职称评定个人总结
2015/03/05 职场文书
企业党建工作总结2015
2015/05/26 职场文书
运动会广播稿20字
2015/08/19 职场文书