setTimeout和setInterval的区别你真的了解吗?_javascript技巧
甚至可能会错误的把两个实现定时调用的函数理解成了类似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代码
比如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);
这个估计稍微想一下, 就明白其中的好处了, 这样就不会产生时间点被跳过的问题内容就到这里, 希望能有所帮助, 可能我表达的不是很清楚如果觉得自己英语基础不错可以直接看
里有关advanced Timers这节内容, 个人认为这本书真的很不错, 无论是想从零学起, 还是平日没事翻翻参考参考 都很不错, 作者是yahoo里很牛的一位前端开发工程师 : )

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Perbezaan antara settimeout dan setInterval: 1. Masa pencetus, settimeout adalah satu masa, ia melaksanakan fungsi sekali selepas menetapkan masa tunda, manakala setinterval adalah berulang, ia akan melaksanakan fungsi berulang kali pada selang masa yang ditetapkan , settimeout hanya dilaksanakan sekali, dan setinterval akan dilaksanakan berulang kali sehingga dibatalkan.

Bagaimana untuk menggunakan fungsi setInterval untuk melaksanakan kod dengan kerap? Dalam JavaScript, fungsi setInterval ialah fungsi yang sangat berguna, yang boleh melaksanakan sekeping kod dengan kerap. Melalui fungsi setInterval, kita boleh berulang kali melaksanakan kod tertentu dalam selang masa tertentu. Artikel ini akan memperkenalkan secara terperinci cara menggunakan fungsi setInterval dan memberikan contoh kod khusus. 1. Sintaks asas fungsi setInterval adalah seperti berikut: setInterv

Anda boleh menggunakan fungsi clearInterval untuk menghentikan pemasa yang dibuat oleh fungsi setInterval. Fungsi setInterval mengembalikan ID pemasa unik, yang boleh dihantar sebagai parameter kepada fungsi clearInterval untuk menghentikan pelaksanaan pemasa.

Sintaks asas kaedah Window.setInterval() ialah "window.setInterval(function, delay)", fungsi ialah fungsi atau blok kod yang akan dilaksanakan berulang kali dan lengah ialah selang masa antara setiap pelaksanaan, dalam milisaat. Kaedah ini ialah kaedah dalam JavaScript yang digunakan untuk melaksanakan fungsi atau kod tertentu secara berulang pada masa yang dijadualkan Penggunaannya sangat mudah Anda hanya perlu memasukkan fungsi atau blok kod untuk dilaksanakan dan selang masa untuk pelaksanaan berulang.

Fungsi setInterval ialah fungsi pemasa dalam JavaScript yang membolehkan anda menetapkan selang dan melaksanakan kod yang ditentukan selepas setiap selang Ia amat berguna apabila tugasan tertentu perlu diproses dengan kerap atau elemen halaman dikemas kini dalam masa nyata apabila menggunakan isu prestasi dan kebolehpercayaan setInterval dan mengoptimumkan mengikut keperluan.

Penggunaan setinterval ialah "setInterval(function, delay);", "function" ialah fungsi yang akan dilaksanakan, yang boleh menjadi ungkapan fungsi atau rujukan fungsi, dan "delay" ialah selang masa antara melaksanakan fungsi, dalam milisaat. setInterval ialah fungsi dalam JavaScript yang digunakan untuk melaksanakan kod secara berkala Ia menerima fungsi dan selang masa sebagai parameter, dan akan melaksanakan fungsi itu berulang kali mengikut selang masa yang ditentukan.

setTimeout(function,duration)-Fungsi ini memanggil fungsi selepas tempoh milisaat. Ini berfungsi untuk satu pelaksanaan. Mari lihat contoh - ia menunggu selama 2000 milisaat dan kemudian menjalankan amaran fungsi panggil balik('Hello') - setTimeout(function(){alert('Hello');},2000); ialah Fungsi dipanggil selepas setiap tempoh milisaat. Ini boleh dilakukan tanpa had bilangan kali. Mari lihat contoh - ia mencetuskan penggera setiap 2000 ms

Untuk menggunakan fungsi clearTimeout dalam JavaScript untuk membatalkan pemasa setTimeout, anda memerlukan contoh kod khusus Dalam JavaScript, fungsi setTimeout digunakan untuk melaksanakan kod tertentu selepas kelewatan masa yang ditentukan. Fungsi setInterval digunakan untuk melaksanakan berulang kali kod tertentu dalam selang masa tertentu. Walau bagaimanapun, dalam beberapa kes kita mungkin perlu membatalkan pemasa sebelum ia dilaksanakan. Dalam kes ini, anda boleh menggunakan c
