默认的

setTimeout 只执行一次, 清除用clearTimeout

setInterval 每间隔指定的时间, 就执行一次, 清除用clearInterval

但是, setTimeout也可以用来执行 每隔一定时间间隔就执行一次, 方法是在 函数内部使用 "递归"的调用.

foo(); //调用一次foo函数
function foo(){
// 函数主体
// ... 该数据处理的, 执行数据处理;
// ... 该输出的, 就输出
// ... 该显示的, 你显示
// 主体执行完了 setTimeout(foo, 5000); }
// 这个方法, 是一种 固定的 套路 用法, 固定的写法.

那么 "递归setTimeout" 和 setInterval 的区别?

  • 如果要求 在固定的 精确 间隔时间后, 执行动作, 用setInterval,
  • 如果要避免setInterval 在短间隔时间 连续调用 产生的相互干扰, 特别是 每次函数的调用需要繁重的计算以及很长的处 理时间, 这时更容易产生干扰,此时最好用 setTimeout.
  • setTimeout不会产生干扰: 因为每次执行foo的时候, 总是先把当前这次foo的 函数主体 工作完成后, 再间隔指定时间后, 才会开始执行下一次foo的动作.实际上执行的只是一个 "函数入口" , 是线性的, 有先后次序的, 所以不会发生干扰. 而setInterval 则是 "并行的"....

jquery中也可以使用js原生代码, 只不过要注意和jquery对象相区分,搞清楚到底是js对象还是jquery对象. jquery中没有 "日期时间" 函数,所以还是用 js 原生的 日期-时间 函数:

// 获取当前的日期和时间
var datetime/dt= new Date();
alert(dt)
// datetime 显示的是: 星期 月日年 时间HH:ii:ss GMT+0800

程序代码举例

/*  在setInterval中使用匿名函数. */
<script src="js/jquery-1.10.2.js"></script>
<script type="text/javascript">
$(function() {
var i = 0;
var timer = setInterval(function(){
var dt = new Date();
var month = dt.getMonth()+1;
alert('现在是: '+ dt.getFullYear()+'年, '+ month +'月, '+dt.getDate()) + "日";
i++;
if (i>= 3){
clearInterval(timer); // 在setInterval函数内部, 就可以使用clearInterval清除计时器.
} },500);
});
</script>
/*  在setInterval中使用code,delay参数. */
<script type="text/javascript">
$(function() {
var timer = setInterval(showDate,500); // 这里千万注意, 参数code, 就直接写函数名, 不要加括号,也不要引号 var i = 0; // 这个初始化要放在函数的外面,才能保证只执行3次.
function showDate(){
var dt = new Date();
var month = dt.getMonth()+1;
alert('现在是: '+ dt.getFullYear()+'年, '+ month +'月, '+dt.getDate() + "日");
i++;
if (i>= 3){
clearInterval(timer);
}
}
});
// 使用setTimeout实现多次计时器
// /*===========================================
// * 特别注意的是, var i=0 循环次数控制变量的位置, 放在函数调用前/后,
// * 循环的次数是不同的, 这里如果var i=0 放在showDate()之后, 将会显示4次, 而不是预想的3次
// *===========================================*/ <script type="text/javascript">
$(function() {
// 先 只 调用一次 "包含" 函数
var i = 0;
showDate(); // 定义showDate, 并在函数内部使用: setTimeout(showDate, delay_microsecond) function showDate() { /* 函数主体 跟原来的业务处理 相同 */
i++;
var dt = new Date();
var month = dt.getMonth()+1;
alert('现在是: '+ dt.getFullYear()+'年, '+ month +'月, '+dt.getDate()) + "日";
if (i>= 3){
return;
}
setTimeout(showDate, 500);
} }); </script>

**计算机只做你告诉它该做的事情, 但是, 并不会做你想做的事情!**

setTimeout和setInterval的各自使用场景的更多相关文章

  1. 原生js轮播以及setTimeout和setInterval的理解

    下面这个代码是从一个群下载下来的,为了帮助自己理解和学习现在贴出来,与初学者共勉. <!DOCTYPE html> <html> <head> <meta c ...

  2. setTimeout和setInterval的使用

    引自(http://www.cnblogs.com/qiantuwuliang/archive/2009/06/20/1507304.html) 这两个方法都可以用来实现在一个固定时间段之后去执行Ja ...

  3. 【转】JS中setTimeout和setInterval的最大延时值详解

    前言 JavaScript提供定时执行代码的功能,叫做定时器(timer),主要由setTimeout()和setInterval()这两个函数来完成.而这篇文中主要给大家介绍的是关于JS中setTi ...

  4. settimeout、setinterval区别和相互模拟

    前几天翻书,看到“避免双重求值”一节时有提到settimeout().setinterval() 建议传入函数而不是字符串以作为第一个参数,所以这里总结一下settimeout()和setinterv ...

  5. JS动画三剑客——setTimeout、setInterval、requestAnimationFrame

    一.前言 前端实现动画效果主要有以下几种方法:CSS3中的transition 和 animation ,Javascript 中可以通过定时器 setTimeout.setinterval,HTML ...

  6. 深入理解定时器系列第一篇——理解setTimeout和setInterval

    × 目录 [1]setTimeout [2]setInterval [3]运行机制[4]作用[5]应用 前面的话 很长时间以来,定时器一直是javascript动画的核心技术.但是,关于定时器,人们通 ...

  7. 前端开发:setTimeout与setInterval 定时器与异步循环数组

    前端开发:setTimeout与setInterval 定时器与异步循环数组 前言: 开通博客园三个月以来,随笔记录了工作中遇到的大大小小的难题,也看过无数篇令人启发的文章,我觉得这样的环境是极好的, ...

  8. setTimeout和setInterval从入门到精通

    我们在日常web前端开发中,经常需要用到定时器方法. 前端中的定时器方法是浏览器提供的,并不是ECMAScript规范中的.是window对象的方法. 浏览器中的定时器有两种, 一种是每间隔一定时间执 ...

  9. setTimeout和setInterval定时器使用详解测试

    var len=4; while(len--){ var time=setTimeout(function(){ console.log(len); },0); console.log(time); ...

随机推荐

  1. 【windows】跑大型程序时不要休眠和睡眠

    win10系统. 为了节能,长时间没有操作操作系统会自动进入休眠模式. 先前设定了"控制面板\硬件和声音\电源选项\编辑计划设置",都设定为"从不",结果不起作 ...

  2. 【BZOJ-2438】杀人游戏 Tarjan + 缩点 + 概率

    2438: [中山市选2011]杀人游戏 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1638  Solved: 433[Submit][Statu ...

  3. 【BZOJ-3996】线性代数 最小割-最大流

    3996: [TJOI2015]线性代数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1054  Solved: 684[Submit][Statu ...

  4. JDK与Java SE/EE/ME的区别

    1. Java SE(Java Platform,Standard Edition). Java SE 以前称为 J2SE.它允许开发和部署在桌面.服务器.嵌入式环境和实时环境中使用的 Java 应用 ...

  5. ueditor的优酷插件模式开发,目前开发了腾讯视频转换插件

    项目相关地址 源码:https://github.com/easonjim/ueditor_plugin bug提交:https://github.com/easonjim/ueditor_plugi ...

  6. DedeCMS Xss+Csrf Getshell \dede\file_manage_control.php

    目录 . 漏洞描述 . 漏洞触发条件 . 漏洞影响范围 . 漏洞代码分析 . 防御方法 . 攻防思考 1. 漏洞描述 对这个漏洞的利用方式进行简单的概括 . 这个漏洞的利用前提是需要登录到后台进行操作 ...

  7. Java过滤器与SpringMVC拦截器之间的关系与区别

    今天学习和认识了一下,过滤器和SpringMVC的拦截器的区别,学到了不少的东西,以前一直以为拦截器就是过滤器实现的,现在想想还真是一种错误啊,而且看的比较粗浅,没有一个全局而又细致的认识,由于已至深 ...

  8. MVC5-2 MVC的管道流与路由

    自定义Modue与Hander 之前讲了管道流中的Module与Hndler.现在我们可以去自定义Module和Handler Module 其实很简单,一共需要三个步骤 定义一个类去继承IHttpM ...

  9. gvim e303 无法打开 “[未命名]“的交换文件,恢复将不可能

    今天vim出现:“gvim e303 无法打开 “[未命名]“的交换文件,恢复将不可能” 解决办法: 修改你的.vimrc,增加下面的一行: set directory=.,$TEMP "默 ...

  10. [Android]Volley的使用

    Volley是Google I/O 2013上提出来的为Android提供简单快速网络访问的项目.Volley特别适合数据量不大但是通信频繁的场景. 优势 相比其他网络载入类库,Volley 的优势官 ...