JS中setTimeout和setInterval的最大延时值详解
程序员文章站
2022-07-28 23:22:26
前言
javascript提供定时执行代码的功能,叫做定时器(timer),主要由settimeout()和setinterval()这两个函数来完成。而这篇文中主要给大...
前言
javascript提供定时执行代码的功能,叫做定时器(timer),主要由settimeout()
和setinterval()
这两个函数来完成。而这篇文中主要给大家介绍的是关于js中settimeout和setinterval最大延时值的相关问题,需要的朋友们下面来一起学习学习吧。
先来看这样一段代码:
function update() { loaddata().then(function(data) { $('#content').html(data.content); var delay = data.nextupdatetime - new date(); if (delay > 0) { settimeout(update, delay); } }); }
其流程非常简单:通过ajax加载数据后更新html的内容;如果有指定下次更新时间,则通过计时器在该时间点再执行一次整个流程。
要说这段代码有什么隐患的话,那就是data.nextupdatetime
与当前时间的时间差(即delay变量的值)比较小的时候,会导致内容频繁更新。但这是属于正常的业务逻辑,要优化就只能牺牲内容更新的即时性。然而这里我要说的是,当时间差非常大的时候,也会出现同样的问题。
下面模拟一下这个场景:
function log() { console.log('executed'); } var nextupdatetime = new date(); // 设为一个月后 nextupdatetime.setmonth(nextupdatetime.getmonth() + 1); var delay = nextupdatetime - new date(); settimeout(log, delay);
这段代码的原意是让log函数在一个月后执行,但是运行一下就可以发现,该函数会马上执行。为什么会这样呢?
搜一下相关内容可以发现,settimeout是使用int32来存储延时参数值的,也就是说最大的延时值是2^31-1。一旦超过了最大值,其效果就跟延时值为0的情况一样,也就是马上执行。
这个最大的延时值已经接近一个月了,一般情况下,用户也不会长时间开着一个网页,如果真开了这么久,那就刷新一下吧:
function update() { loaddata().then(function(data) { $('#content').html(data.content); var delay = data.nextupdatetime - new date(); if (delay > 0) { // 限制最大延时值为一天 var one_day = 24 * 60 * 60 * 1000; if (delay > one_day) { settimeout(function() { window.location.reload(); }, one_day); } else { settimeout(update, delay); } } }); }
同样的问题也存在于setinterval中。这也算是javascript中一个比较隐蔽的坑了。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
推荐阅读
-
JS中setTimeout和setInterval的最大延时值详解
-
js中的setInterval和setTimeout使用实例
-
js中的setInterval和setTimeout使用实例_基础知识
-
快速掌握Node.js中setTimeout和setInterval的使用方法
-
快速掌握Node.js中setTimeout和setInterval的使用方法
-
js中的setInterval和setTimeout使用实例_基础知识
-
JS中setTimeout和setInterval的最大延时值详解
-
快速掌握Node.js中setTimeout和setInterval的使用方法_node.js
-
Js中setTimeout()和setInterval() 何时被调用执行的用法_基础知识
-
js中的setInterval和setTimeout使用实例