中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > 解讀javascript的計時器 I
關(guān)于浮動的前世今生 回到列表 使用jQuery改進文件上傳控件
 解讀javascript的計時器 I

作者:dishuipiaoxiang 時間: 2009-08-17 文檔類型:翻譯 來自:

第 1 頁 解讀javascript的計時器 [1]
第 2 頁 解讀javascript的計時器 [2]
第 3 頁 解讀javascript的計時器 [3]

既然javascript在一定時間內(nèi)之執(zhí)行一部分代碼(源于單線程的特性),那么這些代碼塊的每一個就被封鎖在其它異步事件執(zhí)行的進程中。這表明當一個異步事件發(fā)生時(如鼠標點擊、計時器釋放、XMLHttpRequest請求完成),它將排隊等候執(zhí)行(如何排隊在不同瀏覽器之間是不一樣的)。

首先,在第一代碼塊里,有兩個計時器觸發(fā):一個是10ms的setTimeout,一個是10ms的setInterval。在第一個代碼塊真正完成之前,它實際上已經(jīng)釋放了。但是,注意,它不會立即執(zhí)行(由于單線程的問題,它無能為力),相反,為了能在下一個可行的時間得到執(zhí)行,那些延時函數(shù)被編入隊列。

另外,在第一個代碼塊內(nèi),我們看到鼠標點擊出現(xiàn)。與這個異步事件(我們永遠不知道何時執(zhí)行動作,這樣就可以認為它是不同步的)相關(guān)Javascript回調(diào)函數(shù)跟初始的計時器一樣不能立即被執(zhí)行,它排隊等候執(zhí)行。

在Javascript最初的代碼塊執(zhí)行完畢之后,瀏覽器會發(fā)出疑問:正在等候執(zhí)行的是什么?在這種情況下,鼠標點擊處理器和計時器回調(diào)函數(shù)同時處于等待之中,然后,瀏覽器將選擇一個并立即執(zhí)行它,計時器函數(shù)將等到下一個可能的時間執(zhí)行。

注意,當鼠標點擊函數(shù)處理器執(zhí)行時,第一個回調(diào)函數(shù)也在執(zhí)行,至于計時器,其處理器被編入隊列稍后執(zhí)行。但是,請注意,當Interval再次釋放時(在計時器處理器執(zhí)行時),計時器執(zhí)行的時間將減少。如果你在一大塊代碼執(zhí)行期間將所有的Interval回調(diào)函數(shù)編入隊列,其結(jié)果是一大群Interval回調(diào)函數(shù)會毫無延遲的執(zhí)行,直到全部完成。而瀏覽器在隊列增大之前只是簡單的等到?jīng)]有Interval處理器排隊為止(間歇問題)。

事實上,我們看到這樣一個情況:Interval正在執(zhí)行時,第三個Interval函數(shù)將釋放。這表明一個重要的事實:Interval對當前正在執(zhí)行什么漠不關(guān)心,它們將不會青紅皂白的排隊,即使是犧牲回調(diào)函數(shù)之間的時間也在所不辭。

最后,在第二個Interval函數(shù)執(zhí)行完畢之后,我們可以看到?jīng)]有留下任何Javascript引擎執(zhí)行的東西。也就是說,瀏覽器在等待一個新的異步事件的出現(xiàn)。Interval再次釋放時,我們在50ms處獲得它,但這一次,執(zhí)行起來沒有任何障礙,它立即釋放。

我們來看一個例子,以便更好的說明setTimeout和setInterval的差異:

setTimeout(function(){
/* Some long block of code... */
setTimeout(arguments.callee, 10);
}, 10);
setInterval(function(){
/* Some long block of code... */
}, 10);

乍一看,這兩段代碼似乎功能相同,但并非如此。setTimeout代碼在前一個回調(diào)函數(shù)執(zhí)行萬之后,至少有10ms的延遲(最終可能多些,但至少不會少于此),而setInterval將每隔10ms嘗試執(zhí)行一次回調(diào)函數(shù)而不管最后一個回調(diào)函數(shù)何時執(zhí)行。

這里有很多我們需要了解,讓我們回顧一下:

  1. Javascript只有單線程,異步事件被迫排隊等候執(zhí)行;
  2. setTimeout和setInterval在如何執(zhí)行異步代碼方面有根本的區(qū)別;
  3. 如果計時器無法立即執(zhí)行,它將延時到下一個可能的時間執(zhí)行(這比預想的延遲時間要長一些);
  4. 如果有充分的執(zhí)行時間,Interval可能會毫無延遲的來回執(zhí)行。

所有這些無疑是重要的知識,了解Javascript引擎如何工作,特別是有大量異步事件出現(xiàn)時,這使得在構(gòu)建高級應用代碼片段時有一個良好的基礎。

出處:
責任編輯:
bluehearts

上一頁 解讀javascript的計時器 [1] 下一頁 解讀javascript的計時器 [3]

◎進入論壇網(wǎng)頁制作、WEB標準化版塊參加討論,我還想發(fā)表評論。

相關(guān)文章 更多相關(guān)鏈接
JavaScript獲取事件對象的注意點
JavaScript 浮動定位提示效果
給JavaScript新手的24條實用建議
JavaScript優(yōu)化細節(jié)
JavaScript 實現(xiàn) Konami Code
作者文章
解讀javascript的計時器 II
使用jQuery改進文件上傳控件
自適應css布局——流動布局新時代
圖像替換新技術(shù):狀態(tài)域方法
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設計大賽開啟
國際體驗設計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:2/31個記錄/頁 轉(zhuǎn)到 頁 共3個記錄

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔一切因您的行為而直接或間接導致的民事或刑事法律責任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2