JavaScript中的setTimeout如何使用
我们知道在JavaScript中有两种类型的计时处理器:setInterval和setTimeout,在上一篇文章中我们已经介绍了setInterval定时器,下面的这篇文章我们就来看看JavaScript中的setTimeout定时器的使用方法。
setTimeout() 是属于 window 的方法,该方法用于在指定的毫秒数后调用函数或计算表达式。
基本语法如下
setTimeout(function函数,固定的时间[,参数1,参数2,参数3,.......])
下面我们就来具体看看setTimeout的用法
我们先来看一段简单的代码
<!DOCTYPE html> <html lang = "ja"> <head> <meta charset = "utf-8"> <title>JavaScript</title> </head> <body> <script> var count = 0; var countup = function(){ console.log(count++); } </script> </body> </html>
准备count的变量,以0为基准,一个一个地计数相加(count ++),然后用console.log输出。并且将这一系列的处理放入countupp的变量中。
假设你想在1000毫秒后调用这个变量countup计数,需要添加setTimeout()
代码如下
<script> var count = 0; var countup = function(){ console.log(count++); } setTimeout(countup, 1000); </script>
由于setTimeout只调用一次,因此输出0并在1000毫秒后完成。
如何使用setTimeout()像setInterval()一样迭代计数呢?
我们可以在迭代函数中写入setTimeout,即{},用countup()调用它 ;
代码如下
<script> var count = 0; var countup = function(){ console.log(count++); setTimeout(countup, 1000); } countup();</script>
通过这样做,它从一旦完成处理的点开始再次重复相同的过程1000毫秒。
运行效果如下:处理类似于setInterval的行为。
如果想要停止计数,我们需要使用clearTimeout。
代码如下
var id = setTimeoutl(countup,1000);
通过使用clearTimeout指定此id ,您可以随时停止setTimeout处理(很明显,停止处理了)
<script> var count = 0; var countup = function(){ console.log(count++); var id = setTimeout(countup, 1000); if(count > 5){ clearTimeout(id); } } countup(); </script>
在上面的程序中,当执行setTimeout的计数并且countup变为大于5(if(count> 5))时,执行clearTimeout。
因此,它最多可以计数到5。
最后,我们来简单看一下setInterval计数和使用setTimeout计数之间的区别
在使用setInterval进行迭代处理的情况下:在从处理起始点开始的一定时间后重复相同的处理
迭代setTimeout时:从处理结束点开始经过一段时间后重复相同的处理
因此,即使你在相同的1000毫秒之后指定时间,开始下一个过程所需的时间也会发生变化。
此外,如果一个进程所需的时间超过间隔时间,则行为将是有缺陷的。如果你想确保处理和处理之间有一定的余量,我们可以使用setTimeout。
以上就是JavaScript中的setTimeout如何使用的详细内容,更多请关注其它相关文章!
推荐阅读
-
JavaScript 是如何工作的:JavaScript 的内存模型
-
node.js中的fs.linkSync方法使用说明_node.js
-
PPT2007中如何将单调的文字处理成对角线颜色不一的文本效果
-
编写一个函数 reverse_string(char * string)(递归实现) 实现:将参数字符串中的字符反向排列。 要求:不能使用C函数库中的字符串操作函数。
-
Word2010如何将计算机上的图片和照片插入到段落的第二行中
-
PowerPoint文本框输入使用字体中的下标效果为字符设置下标
-
Word2003中如何随心所欲的旋转图片达到预期的效果
-
javaScript中var、let、const的区别
-
Word2010中看不到表格网格线如何调出隐藏的表格网格线
-
在AspNetCore中扩展Log系列 - 介绍开源类库的使用(一)