Maison interface Web js tutoriel setTimeout和setInterval的区别你真的了解吗?_javascript技巧

setTimeout和setInterval的区别你真的了解吗?_javascript技巧

May 16, 2016 pm 06:08 PM
setinterval settimeout

甚至可能会错误的把两个实现定时调用的函数理解成了类似thread一样的东西, 认为会在一个时间片内, 并发的执行调用的函数, 似乎很好很强大, 但其实并不是如此, 实际的情况是javascript都是以单线程的方式运行于浏览器的javascript引擎中的, setTimeout和setInterval的作用只是把你要执行的代码在你设定的一个时间点插入js引擎维护的一个代码队列中, 插入代码队列并不意味着你的代码就会立马执行的,理解这一点很重要. 而且setTimeout和setInterval还有点不一样.

先谈谈setTimeout

复制代码 代码如下:

function click() {
// code block1...
setTimeout(function() {
// process ...
}, 200);
// code block2
}

假设我们给一个button的onclick事件绑定了此方法, 当我们按下按钮后, 肯定先执行block1的内容, 然后运行到setTimeout的地方, setTimeout会告诉浏览器说, "200ms后我会插一段要执行的代码给你的队列中", 浏览器当然答应了(注意插入代码并不意味着立马执行), setTimeout代码运行后, 紧跟其后的block2代码开始执行, 这里就开始说明问题了, 如果block2的代码执行时间超过200ms, 那结果会是如何? 或许按照你之前的理解, 会理所当然的认为200ms一到, 你的process代码会立马执行...事实是, 在block2执行过程中(执行了200ms后)process代码被插入代码队列, 但一直要等click方法执行结束, 才会执行process代码段, 从代码队列上看process代码是在click后面的, 再加上js以单线程方式执行, 所以应该不难理解. 如果是另一种情况, block2代码执行的时间再看看setInterval
这里可能会存在两个问题:
1.时间间隔或许会跳过
2.时间间隔可能
复制代码 代码如下:

function click() {
// code block1...
setInterval(function() {
// process ...
}, 200);
// code block2
}

和上面一样我们假设通过一个click, 触发了setInterval以实现每隔一个时间段执行process代码

setTimeout和setInterval的区别你真的了解吗?_javascript技巧

比如onclick要300ms执行完, block1代码执行完, 在5ms时执行setInterval, 以此为一个时间点, 在205ms时插入process代码, click代码顺利结束, process代码开始执行(相当于图中的timer code), 然而process代码也执行了一个比较长的时间, 超过了接下来一个插入时间点405ms, 这样代码队列后又插入了一份process代码, process继续执行着, 而且超过了605ms这个插入时间点, 下面问题来, 可能你还会认为代码队列后面又会继续插入一份process代码...真实的情况是,由于代码队列中已经有了一份未执行的process代码, 所以605ms这个插入时间点将会被"无情"的跳过, 因为js引擎只允许有一份未执行的process代码, 说到这里不知道您是不是会豁然开朗呢...

为了这种情况你可以用一种更好的代码形式

复制代码 代码如下:

setTimeout(function(){
//processing
setTimeout(arguments.callee, interval);
}, interval);

这个估计稍微想一下, 就明白其中的好处了, 这样就不会产生时间点被跳过的问题内容就到这里, 希望能有所帮助, 可能我表达的不是很清楚如果觉得自己英语基础不错可以直接看

setTimeout和setInterval的区别你真的了解吗?_javascript技巧
里有关advanced Timers这节内容,  个人认为这本书真的很不错, 无论是想从零学起, 还是平日没事翻翻参考参考 都很不错, 作者是yahoo里很牛的一位前端开发工程师 : )

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quelle est la différence entre settimeout et setinterval Quelle est la différence entre settimeout et setinterval Aug 15, 2023 pm 02:06 PM

La différence entre settimeout et setInterval : 1. Temps de déclenchement, settimeout est unique, il exécute la fonction une fois après avoir défini le temps de retard, tandis que setinterval est répétitif, il exécutera la fonction à plusieurs reprises à l'intervalle de temps défini ; , settimeout n'est exécuté qu'une seule fois et setinterval sera exécuté à plusieurs reprises jusqu'à son annulation.

Comment utiliser la fonction setInterval pour exécuter du code régulièrement ? Comment utiliser la fonction setInterval pour exécuter du code régulièrement ? Nov 18, 2023 pm 05:00 PM

Comment utiliser la fonction setInterval pour exécuter du code régulièrement ? En JavaScript, la fonction setInterval est une fonction très utile, qui permet d'exécuter un morceau de code régulièrement. Grâce à la fonction setInterval, nous pouvons exécuter à plusieurs reprises le code spécifié dans un intervalle de temps spécifique. Cet article présentera en détail comment utiliser la fonction setInterval et fournira des exemples de code spécifiques. 1. La syntaxe de base de la fonction setInterval est la suivante : setInterv

Comment arrêter setInterval Comment arrêter setInterval Dec 11, 2023 am 11:39 AM

Vous pouvez utiliser la fonction clearInterval pour arrêter une minuterie créée par la fonction setInterval. La fonction setInterval renvoie un ID de minuterie unique, qui peut être transmis en tant que paramètre à la fonction clearInterval pour arrêter l'exécution de la minuterie.

Comment utiliser la méthode Window.setInterval() Comment utiliser la méthode Window.setInterval() Aug 31, 2023 am 09:33 AM

La syntaxe de base de la méthode Window.setInterval() est "window.setInterval(function, delay)", la fonction est la fonction ou le bloc de code à exécuter à plusieurs reprises, et le délai est l'intervalle de temps entre chaque exécution, en millisecondes. Cette méthode est une méthode en JavaScript utilisée pour exécuter à plusieurs reprises une fonction ou un code spécifié à une heure planifiée. Son utilisation est très simple. Il vous suffit de transmettre la fonction ou le bloc de code à exécuter et l'intervalle de temps pour une exécution répétée.

définirIntervalle définirIntervalle Aug 02, 2023 am 10:17 AM

La fonction setInterval est une fonction de minuterie en JavaScript qui vous permet de définir un intervalle et d'exécuter du code spécifié après chaque intervalle. Elle est très utile lorsque certaines tâches doivent être traitées régulièrement ou que les éléments de la page sont mis à jour en temps réel. lors de l'utilisation de setInterval, problèmes de performances et de fiabilité et optimisation si nécessaire.

Explication détaillée de l'utilisation de setinterval Explication détaillée de l'utilisation de setinterval Sep 12, 2023 am 09:55 AM

L'utilisation de setinterval est "setInterval(function, delay);", "function" est la fonction à exécuter, qui peut être une expression de fonction ou une référence de fonction, et "delay" est l'intervalle de temps entre l'exécution des fonctions, en millisecondes. setInterval est une fonction en JavaScript utilisée pour exécuter du code périodiquement. Elle accepte une fonction et un intervalle de temps comme paramètres et exécutera la fonction à plusieurs reprises en fonction de l'intervalle de temps spécifié.

Quelle est la différence entre setTimeout() et setInterval() en JavaScript ? Quelle est la différence entre setTimeout() et setInterval() en JavaScript ? Sep 01, 2023 pm 03:01 PM

setTimeout(function,duration) - Cette fonction appelle la fonction après une durée de quelques millisecondes. Cela fonctionne pour une seule exécution. Voyons un exemple - il attend 2000 millisecondes puis exécute la fonction de rappel alert('Hello') - setTimeout(function(){alert('Hello');},2000); setInterval(function,uration) - cette fonction is La fonction est appelée toutes les millisecondes de durée. Cela peut être fait un nombre illimité de fois. Voyons un exemple - il déclenche une alarme toutes les 2000 ms

Utilisez la fonction clearTimeout en JavaScript pour annuler le minuteur setTimeout Utilisez la fonction clearTimeout en JavaScript pour annuler le minuteur setTimeout Nov 18, 2023 am 08:05 AM

Pour utiliser la fonction clearTimeout en JavaScript pour annuler le minuteur setTimeout, vous avez besoin d'exemples de code spécifiques. En JavaScript, la fonction setTimeout est utilisée pour exécuter un code spécifique après un délai spécifié. La fonction setInterval est utilisée pour exécuter à plusieurs reprises un code spécifique dans un intervalle de temps spécifié. Cependant, dans certains cas, nous devrons peut-être annuler le minuteur avant son exécution. Dans ce cas, vous pouvez utiliser c

See all articles