定时器

1、含义:

JavaScript提供一些原生方法来实现让某一段代码延时执行的功能。
JS的定时器目前有三个:setTimeout、setInterval和setImmediate。

2、setTimeout(function(){},时间)延迟定时器

在指定的毫秒数后调用函数或计算表达式,只执行一次
延迟时间以毫秒(ms)为单位,1s=1000ms
一般用于咨询弹框、网站广告弹窗等相关操作。

setTimeout(fn, x)表示延迟x毫秒之后执行fn,只执行一次。
var 要设置定时器的标签的Id = setTimeout(function(){
        要延迟执行的代码
    },延迟时间)

var获取或声明最好提前,代码段只写一个要执行代码的名就行

3、setInterval(function(){},时间)间歇定时器

按照指定的周期(以毫秒计)来调用函数或计算表达式。方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭,重复执行
延迟时间以毫秒(ms)为单位,1s=1000ms
一般用于轮播图、倒计时、抽奖等相关操作。

setInterval(fn, x)表示每隔x毫秒执行一次fn,不断执行。
var 要设置定时器的标签的Id = setInterval(function(){
        要间歇执行的代码
    },间歇时间)

var获取或声明最好提前,代码段只写一个要执行代码的名就行

4、清除定时器

(1)清除延迟定时器clearTimeout
 clearTimeout(要清除定时器的ID);
(2)清除间歇定时器clearInterval
 clearInterval(要清除定时器的ID);

5、常见问题

定时器引起的代码超级无敌托马斯回旋式爆炸阻塞

(1)setInterval多次调用后执行频率为什么越来越快?
window.clearTimeout(int);
window.clearInterval(int);

这两种清除延时的方式,除了语法有区别,清除延时的效果上是等效的,而且无论设置的定时器是哪一种 都可以使用以上任意一种清除掉。

(2)调用定时器时,连续点击按钮,定时器间隔的时间会变短

在函数内部,我们可以先清除定时器再设置定时器。这样的话,每次点击事件发生时,都把前一个定时器清除,再重先开启一个新的定时器

6、剖析

setTimeout(fn,x)表示延迟x毫秒后执行fn,但是严格来说延迟的时间往往是大于x毫秒的,至于大多少要看JS的执行情况。

多个定时器如果不及时清除,会存在干扰,所以不管定时器有没有执行完,都要及时清除一下定时器

HTML5规范规定最小延迟时间不能小于4ms,即x如果小于4,会被当做4来处理。 不过不同浏览器的实现不一样,比如,Chrome可以设置1ms,IE11/Edge是4ms。

setTimeout注册的函数fn会交给浏览器的定时器模块来管理,延迟时间到了就将fn加入主进程执行队列,如果队列前面还有没有执行完的代码,则又需要花一点时间等待才能执行到fn,所以实际的延迟时间会比设置的长。如在fn之前正好有一个超级大循环,那延迟时间就不是一丁点了。

setInterval在重复执行时并不管上一次fn的执行结果而是每隔x毫秒就将fn放入主线程队列执行,而两次fn之间具体间隔多久,和JS执行情况有关。

编码实战

1、超时调用setTimeout和setInterval

setTimeout

<script>
    setTimeout(function(){          //建立延迟定时器
       console.log('狼来了!');    //设置要求打印“狼来了”的函数
                          },2000)   //要求2000毫秒即2秒后打印
</script>

在这里插入图片描述
setInterval

<script>
    setInterval(function(){          //建立间歇定时器
        console.log('狼来了!');    //设置要求打印“狼来了”的函数
                           },2000)    //要求每隔2000毫秒即每隔2秒后打印
</script>

在这里插入图片描述

2、清除定时器clearTimeout和clearInterval

因为clearTimeout和clearInterval在清除定时器时效果一样,可以用任意一个来清除定时器,所以这里就用clearInterval一个来举例。

<script>
  var timer = setInterval(function(){          //声明一个新的定时器ID名字:timer,建立间歇定时器
        console.log('狼来了!');    //设置要求打印“狼来了”的函数
                       },2000)    //要求每隔2000毫秒即每隔2秒后打印
        // clearInterval(timer)
        clearTimeout(timer)   //清除ID名字为timer的定时器
</script>

此代码同上面1中的setInterval,以此为基础进行举例,因为1中的未命名,为了清除定时器方便所以需要声明一个新的ID名字。
3、关不掉的广告(未完,持续更新中)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于计算机专业的学生而言,参加各类比赛能够带来多方面的益处,具体包括但不限于以下几点: 技能提升: 参与比赛促使学生深入学习和掌握计算机领域的专业知识与技能,如编程语言、算法设计、软件工程、网络安全等。 比赛通常涉及实际问题的解决,有助于将理论知识应用于实践中,增强问题解决能力。 实践经验: 大多数比赛都要求参赛者设计并实现解决方案,这提供了宝贵的动手操作机会,有助于积累项目经验。 实践经验对于计算机专业的学生尤为重要,因为雇主往往更青睐有实际项目背景的候选人。 团队合作: 许多比赛鼓励团队协作,这有助于培养学生的团队精神、沟通技巧和领导能力。 团队合作还能促进学生之间的知识共享和思维碰撞,有助于形成更全面的解决方案。 职业发展: 获奖经历可以显著增强简历的吸引力,为求职或继续深造提供有力支持。 某些比赛可能直接与企业合作,提供实习、工作机会或奖学金,为学生的职业生涯打开更多门路。 网络拓展: 比赛是结识同行业人才的好机会,可以帮助学生建立行业联系,这对于未来的职业发展非常重要。 奖金与荣誉: 许多比赛提供奖金或奖品,这不仅能给予学生经济上的奖励,还能增强其成就感和自信心。 荣誉证书或奖状可以证明学生的成就,对个人品牌建设有积极作用。 创新与研究: 参加比赛可以激发学生的创新思维,推动科研项目的开展,有时甚至能促成学术论文的发表。 个人成长: 在准备和参加比赛的过程中,学生将面临压力与挑战,这有助于培养良好的心理素质和抗压能力。 自我挑战和克服困难的经历对个人成长有着深远的影响。 综上所述,参加计算机领域的比赛对于学生来说是一个全面发展的平台,不仅可以提升专业技能,还能增强团队协作、沟通、解决问题的能力,并为未来的职业生涯奠定坚实的基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值