百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

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,通常只应用在登录、交易等少数环境中。但随着越来越多的重要...

取消回复欢迎 发表评论: