JavaScript 定时器和延时器 js定时器执行顺序
suiw9 2024-11-09 14:50 20 浏览 0 评论
关于定时器setInterval(code, millisecond)和延时器setTimeout(code, millisecond)中第一个参数引号问题思考
对于自定义函数使用双引号必须加上括号;
setInterval("start()", 1000);
setTimeout("start()", 1000);
可以简化为
setInterval(start, 1000);
setTimeout(start, 1000);
start 为自定义函数的名称
停止定时器和延时器的函数
clearInterval()
clearTimeout()
对于执行语句中变量必须使用字符串连接符"+", 并且外引号对应;
执行语句使用双引号:
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script type="text/javascript">
window.onload = function(){
var i=10;
timer = setTimeout("alert('骨干分"+i+"子')",3000); //注意引号和变量的使用方式
}
function stop(){
clearTimeout(timer);
}
</script>
</head>
<body>
<button onclick="stop()">停止</button>
</body>
</html>
执行语句使用单引号
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script type="text/javascript">
window.onload = function(){
var i=10;
timer = setTimeout('alert("我是第'+i+'个人")',3000); //注意引号和变量的使用方式
}
function stop(){
clearTimeout(timer);
}
</script>
</head>
<body>
<button onclick="stop()">停止</button>
</body>
</html>
直接使用匿名函数:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script type="text/javascript">
window.onload = function(){
var i=10;
timer = setTimeout(function(){
alert("我是第"+i+"个人");
},3000); //注意引号和变量的使用方式
}
function stop(){
clearTimeout(timer);
}
</script>
</head>
<body>
<button onclick="stop()">停止</button>
</body>
</html>
以上三个案例:只弹出一次警告框"我是第10个人"
实例1:简单计时器
第一种方法:使用延时器
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
<title>网页标题</title>
<script type="text/javascript">
//实现简单的计时器
var i = 0;
var timer;
function start(){
i++;
//第一步:要获取到id=res这个对象
var btnObj = document.getElementById("res");
btnObj.innerHTML = "程序运行了<font color='red'>"+i+"</font>秒";
//使用延时器 每隔1秒后调用这个函数
timer = setTimeout("start()",1000); //使用递归函数
}
//所谓的停止 就是用来清除延时器
function stop(){
clearTimeout(timer);
}
</script>
</head>
<body>
<button id="res">程序运行了0秒</button><br/>
<button onclick="start()">开始</button>
<button onclick="stop()">停止</button>
</body>
</html>
第二种方法:使用定时器
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script type="text/javascript">
var i=0
function start(){
var oBtn = document.getElementById("btn");
timer= setInterval(function(){ //使用匿名函数
oBtn.innerHTML = "程序运行了"+i+"秒";
i++;
}, 1000);
}
function stop(){
clearInterval(timer);
}
</script>
</head>
<body>
<button id="btn">程序运行了0秒</button><br />
<button onclick="start()">开始</button>
<button onclick="stop()">停止</button>
</body>
</html>
做简单计时器两种方法的比较:
延时器要使用递归函数, 定时器不必使用递归函数
实例2: 文字滚动:
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>Document</title>
<script type="text/javascript">
//当页面加载完成后
window.onload = function(){
window.setInterval("start()",50);
}
var str = "武汉传智PHP1期基础班";
var str_leng = str.length; //这个字符串初始的长度
var flag = "right"; //人为定义一个方向 来告诉向右走
//这个函数的功能主要是用于实现文字滚动
//1.需要先获取id=input这个对象 然后给这个对象的value前面加空格
function start(){
var inputObj = document.getElementById('input');
if(flag == "right"){
//向右
//获取id=input这个对象
str = " "+str;
//再kongge这个字符串赋值给inputObj这个对象的value
inputObj.value = str;
if(str.length == 55){
flag = "left";
}
}else{
//向左
//每隔50毫秒删除一个空格
str = str.substr(1);
inputObj.value = str;
if(str.length == str_leng){
flag = "right";
}
}
}
</script>
</head>
<body>
<input id='input' size="40" />
</body>
</html>
实例3: 图片轮播
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style type="text/css">
.box{
width:500px;
height:160px;
margin:50px auto;
}
</style>
<script type="text/javascript">
window.onload = function(){
setInterval("start()",500);
}
var i=1;
function start(){
var oImg = document.getElementById("img");
i++;
oImg.src = "image/dd_scroll_"+i+".jpg";
if(i==6){
i=0;
}
}
</script>
</head>
<body>
<div class="box">
<img src="image/dd_scroll_1.jpg" id="img"/>
</div>
</body>
</html>
实例4: 倒计时
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css">
button{
width: 100px;
}
</style>
</head>
<body>
<button>发送验证码</button>
<script type="text/javascript">
var btn = document.getElementsByTagName("button")[0];
var num = 10;
var timer = null;
btn.onclick = function(){
btn.disabled = "disabled";
clearInterval(timer);
timer = setInterval(function(){
if(num===-1){
clearInterval(timer);//如果num=0我就让定时器停下来
btn.removeAttribute("disabled");
num = 10;
btn.innerText = "发送验证码";
}else{
btn.innerText = num+"s";
num--;
}
},1000)
}
</script>
</body>
</html>
实例5:显示动态时间
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>动态显示时间</title>
<style type="text/css">
#times{
width: 200px;
height: 20px;
border: 3px solid gray; /*如果不加实线无法显示边框*/
}
</style>
</head>
<body>
<div id="times">
</div>
<script type="text/javascript">
//得到时间并写入div
function getDate(){
//获取当前时间
var date = new Date();
//格式化为本地时间格式
var date1 = date.toLocaleString();
//获取div
var div1 = document.getElementById("times");
//将时间写入div
div1.innerHTML = date1;
}
//使用定时器每秒向div写入当前时间
setInterval("getDate()",1000);
</script>
</body>
</html>
实例6: 随机点名
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css">
*{
margin: 0;
padding: 0;
}
div{
width: 200px;
height: 60px;
font-size: 36px;
text-align: center;
line-height: 60px;
border: 1px solid #000;
margin: 100px auto;
}
</style>
</head>
<body>
<button id="start">开始</button>
<button id="end">结束</button>
<div id="div">梁永灿</div>
<script type="text/javascript">
//准备人名
var arr = ["张三","李四","王五","老六"];
var timer = null;
start.onclick = function(){
//以防沙雕用户频繁点击 我每次点击都把上一次的定时器清空
clearInterval(timer);
timer = setInterval(function(){
div.innerText = arr[Math.floor(Math.random()*arr.length)];
},10)
}
end.onclick = function(){
clearInterval(timer);
}
</script>
</body>
</html>
相关推荐
- 俄罗斯的 HTTPS 也要被废了?(俄罗斯网站关闭)
-
发布该推文的ScottHelme是一名黑客,SecurityHeaders和ReportUri的创始人、Pluralsight作者、BBC常驻黑客。他表示,CAs现在似乎正在停止为俄罗斯域名颁发...
- 如何强制所有流量使用 HTTPS一网上用户
-
如何强制所有流量使用HTTPS一网上用户使用.htaccess强制流量到https的最常见方法可能是使用.htaccess重定向请求。.htaccess是一个简单的文本文件,简称为“.h...
- https和http的区别(https和http有何区别)
-
“HTTPS和HTTP都是数据传输的应用层协议,区别在于HTTPS比HTTP安全”。区别在哪里,我们接着往下看:...
- 快码住!带你十分钟搞懂HTTP与HTTPS协议及请求的区别
-
什么是协议?网络协议是计算机之间为了实现网络通信从而达成的一种“约定”或“规则”,正是因为这个“规则”的存在,不同厂商的生产设备、及不同操作系统组成的计算机之间,才可以实现通信。简单来说,计算机与网络...
- 简述HTTPS工作原理(简述https原理,以及与http的区别)
-
https是在http协议的基础上加了一层SSL(由网景公司开发),加密由ssl实现,它的目的是为用户提供对网站服务器的身份认证(需要CA),以至于保护交换数据的隐私和完整性,原理如图示。1、客户端发...
- 21、HTTPS 有几次握手和挥手?HTTPS 的原理什么是(高薪 常问)
-
HTTPS是3次握手和4次挥手,和HTTP是一样的。HTTPS的原理...
- 一次安全可靠的通信——HTTPS原理
-
为什么HTTPS协议就比HTTP安全呢?一次安全可靠的通信应该包含什么东西呢,这篇文章我会尝试讲清楚这些细节。Alice与Bob的通信...
- 为什么有的网站没有使用https(为什么有的网站点不开)
-
有的网站没有使用HTTPS的原因可能涉及多个方面,以下是.com、.top域名的一些见解:服务器性能限制:HTTPS使用公钥加密和私钥解密技术,这要求服务器具备足够的计算能力来处理加解密操作。如果服务...
- HTTPS是什么?加密原理和证书。SSL/TLS握手过程
-
秘钥的产生过程非对称加密...
- 图解HTTPS「转」(图解http 完整版 彩色版 pdf)
-
我们都知道HTTPS能够加密信息,以免敏感信息被第三方获取。所以很多银行网站或电子邮箱等等安全级别较高的服务都会采用HTTPS协议。...
- HTTP 和 HTTPS 有何不同?一文带你全面了解
-
随着互联网时代的高速发展,Web服务器和客户端之间的安全通信需求也越来越高。HTTP和HTTPS是两种广泛使用的Web通信协议。本文将介绍HTTP和HTTPS的区别,并探讨为什么HTTPS已成为We...
- HTTP与HTTPS的区别,详细介绍(http与https有什么区别)
-
HTTP与HTTPS介绍超文本传输协议HTTP协议被用于在Web浏览器和网站服务器之间传递信息,HTTP协议以明文方式发送内容,不提供任何方式的数据加密,如果攻击者截取了Web浏览器和网站服务器之间的...
- 一文让你轻松掌握 HTTPS(https详解)
-
一文让你轻松掌握HTTPS原文作者:UC国际研发泽原写在最前:欢迎你来到“UC国际技术”公众号,我们将为大家提供与客户端、服务端、算法、测试、数据、前端等相关的高质量技术文章,不限于原创与翻译。...
- 如何在Spring Boot应用程序上启用HTTPS?
-
HTTPS是HTTP的安全版本,旨在提供传输层安全性(TLS)[安全套接字层(SSL)的后继产品],这是地址栏中的挂锁图标,用于在Web服务器和浏览器之间建立加密连接。HTTPS加密每个数据包以安全方...
- 一文彻底搞明白Http以及Https(http0)
-
早期以信息发布为主的Web1.0时代,HTTP已可以满足绝大部分需要。证书费用、服务器的计算资源都比较昂贵,作为HTTP安全扩展的HTTPS,通常只应用在登录、交易等少数环境中。但随着越来越多的重要...
你 发表评论:
欢迎- 一周热门
-
-
Linux:Ubuntu22.04上安装python3.11,简单易上手
-
宝马阿布达比分公司推出独特M4升级套件,整套升级约在20万
-
MATLAB中图片保存的五种方法(一)(matlab中保存图片命令)
-
别再傻傻搞不清楚Workstation Player和Workstation Pro的区别了
-
Linux上使用tinyproxy快速搭建HTTP/HTTPS代理器
-
如何提取、修改、强刷A卡bios a卡刷bios工具
-
Element Plus 的 Dialog 组件实现点击遮罩层不关闭对话框
-
日本组合“岚”将于2020年12月31日停止团体活动
-
SpringCloud OpenFeign 使用 okhttp 发送 HTTP 请求与 HTTP/2 探索
-
tinymce 号称富文本编辑器世界第一,大家同意么?
-
- 最近发表
- 标签列表
-
- dialog.js (57)
- importnew (44)
- windows93网页版 (44)
- yii2框架的优缺点 (45)
- tinyeditor (45)
- qt5.5 (60)
- windowsserver2016镜像下载 (52)
- okhttputils (51)
- android-gif-drawable (53)
- 时间轴插件 (56)
- docker systemd (65)
- slider.js (47)
- android webview缓存 (46)
- pagination.js (59)
- loadjs (62)
- openssl1.0.2 (48)
- velocity模板引擎 (48)
- pcre library (47)
- zabbix微信报警脚本 (63)
- jnetpcap (49)
- pdfrenderer (43)
- fastutil (48)
- uinavigationcontroller (53)
- bitbucket.org (44)
- python websocket-client (47)