项目中有用到定时器定时刷新页面的数据,在网上查看了一些资料,整理了一下,备忘。

$timeout

用法如下$timeout(fn,[delay],[invokeApply]);

  • fn:一个将被延迟执行的函数。
  • delay:延迟的时间(毫秒)。
  • invokeApply:如果设置为false,则跳过脏值检测,否则将调用$apply。

方法cancel(promise); 
promise:$timeout函数的返回值。

具体使用:在项目中用到的其中一处是键入字符然后自动发送请求查询,如果每键入一个字符即发送一次请求,在数据库表庞大的时候,数据库肯定会有意见了。这时候就需要用到延时查询了,还需要结合$watch,具体使用如下:

var timeout;
$scope.$watch('idNo', function(newVal, oldVal) {
if(newVal != oldVal) {
if(timeout) {
$timeout.cancel(timeout);
}
timeout = $timeout(function() {
$http.get(url).success(function(data) {});
}, 800);
}
});

如上写法,if(newVal != oldVal){}是默认情况下不查询,键入字符后才会发送请求查询,若想默认情况下就查询则需要去掉该if判断。$timeout.cancel(timeout);是清除上次$itmeout返回的promise。

$interval

用法如下$interval(fn,delay,[count],[invokeApply],[Pass]);

  • fn:一个将被反复执行的函数。
  • delay:每次调用的间隔毫秒数值。
  • count:循环次数的数值,如果没设置,则无限制循环。
  • invokeApply:如果设置为false,则避开脏值检查,否则将调用$apply。
  • Pass:函数的附加参数。

方法cancel(promise); 
promise:$interval函数的返回值。 
具体使用

  1. 经常使用的是
function hello() {
...
console.log("hello world");
}
var timer = $interval(function(){
function hello() {}
},100);
timer.then(function() {
console.log("done");
});

以上是每100毫秒执行hello()函数,每执行完一次则调用then函数。

2. 控制循环的次数:var timer = $interval(function(){},100,10);,参数10则是限制定时器循环10次,若该参数没有定义则表示无数次循环。 
3. 清除interval定时器:通过‘interval.cancle(timer)`删除$interval返回的promise即可清除,而且必须要清除,否则会无限循环。在angular controller中只要开始执行定时任务,只要不清除则会一直执行,无论是否切换到其他的controller和页面,可能会导致不必要的错误。 
4. 项目中用到的完整实例:

// 定时器 定时刷新数据
var timer = $interval(
function() {
hello();//自己定义的每次需要执行的函数,也可以写一些其他的内容
},
5000
);
//当DOM元素从页面中被移除时,AngularJS将会在scope中触发$destory事件。
//这让我们可以有机会来cancel任何潜在的定时器。切换controller、页面后即可调用
$scope.$on(
"$destroy",
function() {
$interval.cancel( timer );
}
);

最新文章

  1. Unity学习笔记
  2. CSS之border
  3. AX2012 审批流流转到已停用的域账号导致审批流停止
  4. metaspolit 基础
  5. andriod网址
  6. topcoder13185 TreePuzzle
  7. Android Fragment详解(一):概述
  8. IIS总提示输入用户名和密码
  9. 一步一步深入spring(7)-- 整合spring和JDBC的环境
  10. 201521123075 《Java程序设计》第12周学习总结
  11. 第2篇 C#数据类型-值类型与引用类型
  12. MySQL常见连接查询
  13. (国内)完美下载Android源码Ubuntu版
  14. Centos6.5部署vsftpd+mysql认证
  15. MSF MS17_010漏洞测试
  16. ES7 之 Async/await 的使用
  17. 51Nod 1810 连续区间
  18. 通过selenium控制浏览器滚动条
  19. netstat 查看端口命令
  20. 论坛:一对一关联映射/单向关联/两个类间,可以有两个(多个)关联关系/content为大文本类型/

热门文章

  1. Python Shell 中敲击方向键显示「^[[C^[[D」,原因是什么?如何修复?
  2. VBS正则表达式
  3. C++ 资源大全中文版
  4. CentOS 7.2 x64 配置SVN服务器
  5. ASP.NET Core多平台部署 (Windows Server+IIS与CentOS 7+Nginx)
  6. FZU - 1606 - Format the expression
  7. Linux查找字符串命令grep(转)
  8. _DataStructure_C_Impl:求图G中从顶点u到顶点v的一条简单路径
  9. UVA 1563 - SETI (高斯消元+逆元)
  10. Project Euler:Problem 77 Prime summations