在制作网页动态效果时,可能会遇到需要延时在执行的需求,这时就可以用到 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() 可以在写代码过程中灵活运用其特点达到需要完成的目的。
- JavaScript正则表达式获取图片链接地址
- 最完整指南 JavaScript 的错误处理
- JavaScript前后端JSON使用方法教程
- 详解JavaScript原型与原型链
- JavaScript 实现拖拽效果组件功能(兼容移动端)
- JavaScript中常用的3种弹出提示框(alert、confirm、prompt)
- 夯基础之手撕javascript继承详解
- JavaScript 实现轮播图特效的示例
版权:版权申明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 70068002@qq.com 举报,一经查实,本站将立刻删除。
转载请注明出处:https://www.stntk.com/2437.html
还没有评论呢,快来抢沙发~