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 相关文章推荐
javascript getElementsByTagName
Jan 31 Javascript
基于jquery的多功能软键盘插件
Jul 25 Javascript
node.js中的fs.ftruncate方法使用说明
Dec 15 Javascript
angularJS Provider、factory、service详解及实例代码
Sep 21 Javascript
javascript中获取元素标签中间的内容的实现方法
Oct 08 Javascript
JavaScript实现数组降维详解
Jan 05 Javascript
微信小程序 action-sheet 反馈上拉菜单简单实例
May 11 Javascript
AngularJS实现select的ng-options功能示例
Jul 12 Javascript
JavaScript多线程运行库Nexus.js详解
Dec 22 Javascript
socket io与vue-cli的结合使用的示例代码
Nov 01 Javascript
微信JS-SDK实现微信会员卡功能(给用户微信卡包里发送会员卡)
Jul 25 Javascript
JavaScript canvas动画实现时钟效果
Feb 10 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
微信扫描二维码登录网站代码示例
2013/12/30 PHP
EarthLiveSharp中cloudinary的CDN图片缓存自动清理python脚本
2017/04/04 PHP
PHP abstract 抽象类定义与用法示例
2018/05/29 PHP
关于__defineGetter__ 和__defineSetter__的说明
2007/05/12 Javascript
让你的网站可编辑的实现js代码
2009/10/19 Javascript
基于jQuery的弹出消息插件 DivAlert之旅(一)
2010/04/01 Javascript
jquery构造器的实现代码小结
2011/05/16 Javascript
在html中引入外部js文件,并调用带参函数的方法
2016/10/31 Javascript
JavaScript中使用webuploader实现上传视频功能(demo)
2017/04/10 Javascript
Bootstrap Table使用整理(五)之分页组合查询
2017/06/09 Javascript
快速搭建vue2.0+boostrap项目的方法
2018/04/09 Javascript
vue 自定义指令自动获取文本框焦点的方法
2018/08/25 Javascript
jQuery实现基本动画效果的方法详解
2018/09/06 jQuery
微信小程序云开发使用方法新手初体验
2019/05/16 Javascript
如何通过shell脚本自动生成vue文件详解
2019/09/10 Javascript
layui 弹出层值回传解决方式
2019/11/14 Javascript
JS Generator 函数的含义与用法实例总结
2020/04/08 Javascript
ES6 Generator基本使用方法示例
2020/06/06 Javascript
vue中defineProperty和Proxy的区别详解
2020/11/30 Vue.js
Python的dict字典结构操作方法学习笔记
2016/05/07 Python
Python中XlsxWriter模块简介与用法分析
2018/04/24 Python
python连接、操作mongodb数据库的方法实例详解
2019/09/11 Python
Django2 连接MySQL及model测试实例分析
2019/12/10 Python
基于TensorFlow常量、序列以及随机值生成实例
2020/01/04 Python
python下载卫星云图合成gif的方法示例
2020/02/18 Python
Pycharm+Python工程,引用子模块的实现
2020/03/09 Python
彪马法国官网:PUMA法国
2019/12/15 全球购物
新西兰Bookabach:查找全球度假屋
2020/12/03 全球购物
教师研修随笔感言
2014/01/23 职场文书
母亲节感恩活动记录
2014/03/16 职场文书
婚假请假条怎么写
2014/04/10 职场文书
群众路线教育实践活动学习心得体会
2014/10/30 职场文书
上甘岭观后感
2015/06/10 职场文书
药品销售员2015年终工作总结
2015/10/22 职场文书
入党转正申请自我鉴定
2019/06/25 职场文书
Redis字典实现、Hash键冲突及渐进式rehash详解
2021/09/04 Redis