欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

setTimeout的延時(shí)為0時(shí)多個(gè)瀏覽器的區(qū)別

 更新時(shí)間:2012年05月23日 18:54:39   作者:  
一直比較迷惑:js的setTimeout到底會在什么時(shí)候執(zhí)行,如果執(zhí)行了,和主執(zhí)行腳本到底差多長時(shí)間
由于不是很了解瀏覽器的內(nèi)部執(zhí)行策略,本文只能是通過前端一些測試依稀猜測些結(jié)論:
1)測試舉例
做了兩個(gè)例子:
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各個(gè)版本瀏覽器下,得到的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)通過點(diǎn)擊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各個(gè)版本瀏覽器下,得到的alert結(jié)果大體為:5左后,偶爾有大值;
  chrome19,基本為2,偶爾為3
  firefox12,基本為1,0,2,但是偶爾也有13左右的值
  safari5.1,基本為1,偶爾為2和3
  opera11.5,基本為4,3,,但是偶爾有12左右的值。
 
  以上測試,均在打開多個(gè)干擾復(fù)雜頁面的標(biāo)簽、單個(gè)標(biāo)簽中測試。結(jié)果差不多。
2)說明什么? 
  其實(shí)也得不到什么結(jié)論,但是測試結(jié)果基本反映了當(dāng)前流行瀏覽器js腳本的效率排名。
  究其原因,可能得出一些印證:
  2-1)由于js的主執(zhí)行線程為單線程,所以此值肯定一般大于0,setTimeout的執(zhí)行時(shí)間點(diǎn)只是加入js主執(zhí)行隊(duì)列中的時(shí)間點(diǎn),至于什么時(shí)候執(zhí)行,是由js引擎線程按順序執(zhí)行的隊(duì)列來決定。此結(jié)論在很多處說到??勺孕胁殚啠?如:JavaScript可否多線程? 深入理解JavaScript定時(shí)機(jī)制);
  此結(jié)論也印證很火時(shí)候用setTimeout做動畫不流暢的原因等。
  順便在此貼出背光的一副圖很能說明問題:

3-2)測試偶爾的很大值,也有可能是js主執(zhí)行線程中做了其他事情,如GC等。因?yàn)榇笾抵貜?fù)出現(xiàn)幾率很少。
 
總結(jié):其實(shí)我是沒有得出結(jié)論,只是好奇,然后猜測,看看可能是情況和結(jié)果,希望大家批評指正。或者有結(jié)論的答復(fù)我。
另外:setTimout函數(shù)中第二個(gè)參數(shù)如果為負(fù)數(shù),則和0具有一樣的效果,如果setTimeout(function(){console.log('test')},-100);等同于setTimeout(function(){console.log('test')},0)。
我以為會報(bào)錯(cuò),結(jié)果所有瀏覽器都沒有報(bào)錯(cuò)。

相關(guān)文章

  • 使用JavaScript和HTML實(shí)現(xiàn)一個(gè)精美的計(jì)算器

    使用JavaScript和HTML實(shí)現(xiàn)一個(gè)精美的計(jì)算器

    計(jì)算器是我們?nèi)粘I钪薪?jīng)常使用的工具之一,可以幫助我們進(jìn)行簡單的數(shù)學(xué)運(yùn)算,在本博文中,我將使用JavaScript編寫一個(gè)漂亮的計(jì)算器,并添加加減乘除功能,感興趣的同學(xué)可以自己動手嘗試一下
    2023-09-09
  • childNodes 用法兩例

    childNodes 用法兩例

    childNodes實(shí)現(xiàn)代碼
    2009-04-04
  • JS實(shí)現(xiàn)動態(tài)給圖片添加邊框的方法

    JS實(shí)現(xiàn)動態(tài)給圖片添加邊框的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)動態(tài)給圖片添加邊框的方法,涉及javascript操作圖片border的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-04-04
  • 輪播圖組件js代碼

    輪播圖組件js代碼

    這篇文章主要為大家介紹了輪播圖組件JavaScript代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • js實(shí)現(xiàn)簡單排列組合的方法

    js實(shí)現(xiàn)簡單排列組合的方法

    這篇文章主要介紹了js實(shí)現(xiàn)簡單排列組合的方法,可實(shí)現(xiàn)數(shù)學(xué)上排列組合算法功能,涉及JavaScript數(shù)組與字符串操作技巧,需要的朋友可以參考下
    2016-01-01
  • 禁止JS運(yùn)行的代碼

    禁止JS運(yùn)行的代碼

    如果我們要讓頁面上的javascript不運(yùn)行,方法最簡單的就是使用noscript標(biāo)簽,經(jīng)常被用來屏蔽那些免費(fèi)空間要加上的JS。
    2011-01-01
  • three.js中文文檔學(xué)習(xí)之通過模塊導(dǎo)入

    three.js中文文檔學(xué)習(xí)之通過模塊導(dǎo)入

    這篇文章主要給大家介紹了關(guān)于three.js中文文檔學(xué)習(xí)之通過模塊導(dǎo)入的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或使用three.js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-11-11
  • 淺析我對JS延遲異步腳本的思考

    淺析我對JS延遲異步腳本的思考

    這篇文章主要介紹了淺析我對JS延遲異步腳本的思考,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • JavaScript判斷數(shù)據(jù)類型有幾種方法及區(qū)別介紹

    JavaScript判斷數(shù)據(jù)類型有幾種方法及區(qū)別介紹

    這篇文章主要介紹了JavaScript判斷數(shù)據(jù)類型有幾種方法及區(qū)別介紹,本文給大家分享多種方法通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • IE和Mozilla的兼容性匯總event

    IE和Mozilla的兼容性匯總event

    IE和Mozilla的兼容性匯總event,需要的朋友可以參考下。
    2007-08-08

最新評論