setTimeout的延時為0時多個瀏覽器的區(qū)別
更新時間:2012年05月23日 18:54:39 作者:
一直比較迷惑:js的setTimeout到底會在什么時候執(zhí)行,如果執(zhí)行了,和主執(zhí)行腳本到底差多長時間
由于不是很了解瀏覽器的內(nèi)部執(zhí)行策略,本文只能是通過前端一些測試依稀猜測些結(jié)論:
1)測試舉例
做了兩個例子:
1-1)腳本在頁面中直接執(zhí)行,通過刷新看結(jié)果
<!DOCTYPE HTML>
<HTML>
<HEAD>
<script type="text/javascript">
var t=new Date;
setTimeout(function(){
alert('cost time:'+(new Date-t))
},0);
</script>
</HEAD>
<BODY>
</BODY>
</HTML>
測試結(jié)果:
在ie各個版本瀏覽器下,得到的alert結(jié)果大體為:14左后,區(qū)間為8~21毫秒之間;
chrome19,基本為1,區(qū)間為1~5之間,但是偶爾會是15左右
firefox12,基本為3,區(qū)間為2~7之間,但是偶爾也有15左右的值
safari5.1,基本為4,區(qū)間為1~7之間,但是偶爾也有15左右的值
opera11.5,基本為5,區(qū)間為2~8之間,但是偶爾有很大值
1-2)通過點擊div看結(jié)果
<!DOCTYPE HTML>
<HTML>
<HEAD>
<script type="text/javascript">
function test(){
var t=new Date;
setTimeout(function(){
alert('cost time:'+(new Date-t))
},0);
}
</script>
</HEAD>
<BODY>
<div onclick='test()' id="div1" style="position:relative;width:200px;height:200px;background-color:green;left:100px;top:100px;">
</div>
</BODY>
</HTML>
測試結(jié)果:
在ie各個版本瀏覽器下,得到的alert結(jié)果大體為:5左后,偶爾有大值;
chrome19,基本為2,偶爾為3
firefox12,基本為1,0,2,但是偶爾也有13左右的值
safari5.1,基本為1,偶爾為2和3
opera11.5,基本為4,3,,但是偶爾有12左右的值。
以上測試,均在打開多個干擾復(fù)雜頁面的標簽、單個標簽中測試。結(jié)果差不多。
2)說明什么?
其實也得不到什么結(jié)論,但是測試結(jié)果基本反映了當前流行瀏覽器js腳本的效率排名。
究其原因,可能得出一些印證:
2-1)由于js的主執(zhí)行線程為單線程,所以此值肯定一般大于0,setTimeout的執(zhí)行時間點只是加入js主執(zhí)行隊列中的時間點,至于什么時候執(zhí)行,是由js引擎線程按順序執(zhí)行的隊列來決定。此結(jié)論在很多處說到??勺孕胁殚啠?如:JavaScript可否多線程? 深入理解JavaScript定時機制);
此結(jié)論也印證很火時候用setTimeout做動畫不流暢的原因等。
順便在此貼出背光的一副圖很能說明問題:
總結(jié):其實我是沒有得出結(jié)論,只是好奇,然后猜測,看看可能是情況和結(jié)果,希望大家批評指正?;蛘哂薪Y(jié)論的答復(fù)我。
另外:setTimout函數(shù)中第二個參數(shù)如果為負數(shù),則和0具有一樣的效果,如果setTimeout(function(){console.log('test')},-100);等同于setTimeout(function(){console.log('test')},0)。
我以為會報錯,結(jié)果所有瀏覽器都沒有報錯。
1)測試舉例
做了兩個例子:
1-1)腳本在頁面中直接執(zhí)行,通過刷新看結(jié)果
復(fù)制代碼 代碼如下:
<!DOCTYPE HTML>
<HTML>
<HEAD>
<script type="text/javascript">
var t=new Date;
setTimeout(function(){
alert('cost time:'+(new Date-t))
},0);
</script>
</HEAD>
<BODY>
</BODY>
</HTML>
測試結(jié)果:
在ie各個版本瀏覽器下,得到的alert結(jié)果大體為:14左后,區(qū)間為8~21毫秒之間;
chrome19,基本為1,區(qū)間為1~5之間,但是偶爾會是15左右
firefox12,基本為3,區(qū)間為2~7之間,但是偶爾也有15左右的值
safari5.1,基本為4,區(qū)間為1~7之間,但是偶爾也有15左右的值
opera11.5,基本為5,區(qū)間為2~8之間,但是偶爾有很大值
1-2)通過點擊div看結(jié)果
復(fù)制代碼 代碼如下:
<!DOCTYPE HTML>
<HTML>
<HEAD>
<script type="text/javascript">
function test(){
var t=new Date;
setTimeout(function(){
alert('cost time:'+(new Date-t))
},0);
}
</script>
</HEAD>
<BODY>
<div onclick='test()' id="div1" style="position:relative;width:200px;height:200px;background-color:green;left:100px;top:100px;">
</div>
</BODY>
</HTML>
測試結(jié)果:
在ie各個版本瀏覽器下,得到的alert結(jié)果大體為:5左后,偶爾有大值;
chrome19,基本為2,偶爾為3
firefox12,基本為1,0,2,但是偶爾也有13左右的值
safari5.1,基本為1,偶爾為2和3
opera11.5,基本為4,3,,但是偶爾有12左右的值。
以上測試,均在打開多個干擾復(fù)雜頁面的標簽、單個標簽中測試。結(jié)果差不多。
2)說明什么?
其實也得不到什么結(jié)論,但是測試結(jié)果基本反映了當前流行瀏覽器js腳本的效率排名。
究其原因,可能得出一些印證:
2-1)由于js的主執(zhí)行線程為單線程,所以此值肯定一般大于0,setTimeout的執(zhí)行時間點只是加入js主執(zhí)行隊列中的時間點,至于什么時候執(zhí)行,是由js引擎線程按順序執(zhí)行的隊列來決定。此結(jié)論在很多處說到??勺孕胁殚啠?如:JavaScript可否多線程? 深入理解JavaScript定時機制);
此結(jié)論也印證很火時候用setTimeout做動畫不流暢的原因等。
順便在此貼出背光的一副圖很能說明問題:
總結(jié):其實我是沒有得出結(jié)論,只是好奇,然后猜測,看看可能是情況和結(jié)果,希望大家批評指正?;蛘哂薪Y(jié)論的答復(fù)我。
另外:setTimout函數(shù)中第二個參數(shù)如果為負數(shù),則和0具有一樣的效果,如果setTimeout(function(){console.log('test')},-100);等同于setTimeout(function(){console.log('test')},0)。
我以為會報錯,結(jié)果所有瀏覽器都沒有報錯。
相關(guān)文章
使用JavaScript和HTML實現(xiàn)一個精美的計算器
計算器是我們?nèi)粘I钪薪?jīng)常使用的工具之一,可以幫助我們進行簡單的數(shù)學(xué)運算,在本博文中,我將使用JavaScript編寫一個漂亮的計算器,并添加加減乘除功能,感興趣的同學(xué)可以自己動手嘗試一下2023-09-09three.js中文文檔學(xué)習(xí)之通過模塊導(dǎo)入
這篇文章主要給大家介紹了關(guān)于three.js中文文檔學(xué)習(xí)之通過模塊導(dǎo)入的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或使用three.js具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11JavaScript判斷數(shù)據(jù)類型有幾種方法及區(qū)別介紹
這篇文章主要介紹了JavaScript判斷數(shù)據(jù)類型有幾種方法及區(qū)別介紹,本文給大家分享多種方法通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09