settimeout可以在一定时间后进行一次特定处理,无需重复,本篇文章我们就来看看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如何使用的详细内容。