欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JavaScript setTimeout()基本用法有哪些

程序员文章站 2022-04-24 18:21:42
在制作网页动态效果时,可能会遇到需要延时在执行的需求,这时就可以用到 js 中定时器来实现此类需求,本文将对settimeout()做一个用法总结。 settimeout() 方法用于在指定的毫秒数...

在制作网页动态效果时,可能会遇到需要延时在执行的需求,这时就可以用到 js 中定时器来实现此类需求,本文将对settimeout()做一个用法总结。

  • settimeout() 方法用于在指定的毫秒数后调用函数或计算表达式(以毫秒为单位)
  • settimeout()只执行函数一次,如果需要多次调用可以使用setinterval(),或者在函数体内再次调用settimeout()

settimeout()用法

举个简单的例子

加入下列代码,在打开的页面静候三秒后,弹出警告框“你好”

<script>
  settimeout("alert('你好')", 3000) 
</script>

效果:

再复杂一些的function定义

<script>
var myvar;

function myfunction() {
  myvar = settimeout(alertfunc, 3000);
}

function alertfunc() {
 alert("hello!");
}

自动每秒加 1 的 function

使用 settimeout( ) 令文字框的数值每秒就加 1, 当然你也可以设定其他递增的速度, 例如每五秒就加 5, 或每五秒就加 1。

<script>
x = 0
function countsecond( )
{ x = x+1
  document.fm.displaybox.value=x
  settimeout("countsecond()", 1000)
}
</script> 
<body bgcolor=lightcyan text=red> <p> </br>
<form name=fm>
<input type="text" name="displaybox"value="0" size=4 >
</form>
<script>
countsecond( )
</script>
</body> 


用上述的方法设定时间, settimeout( ) 虽然设定了是一秒, 但浏览器还有另外两项功能要执行, 所以一个循环的时间是稍多于一秒, 例如一分钟可能只有58 个循环。

延时关闭网页

按下按钮,window open()打开一个网页,执行命令,三秒钟后自动关闭

<button onclick="openwin()">打开 "窗口"</button>
<script>
function openwin() {
  var mywindow = window.open("", "", "width=200, height=100");
  mywindow.document.write("这是一个新窗口");
  settimeout(function(){ mywindow.close() }, 3000);
}
</script>

取消settimeout()

当一个 settimeout( ) 开始了循环的工作, 我们要使它停下来, 可使用 cleartimeout( )

<button onclick="myfunction()">点我弹出</button>
<button onclick="mystopfunction()">阻止弹出</button>
<script>
var myvar;
function myfunction() {
  myvar = settimeout(function(){ alert("hello") }, 2000);
}
function mystopfunction() {
  cleartimeout(myvar);
}
</script>

小结

settimeout(),cleartimeout() , setinterval() 可以在写代码过程中灵活运用其特点达到需要完成的目的

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。