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

游覽器中javascript的執(zhí)行過程(圖文)

 更新時間:2012年05月20日 20:00:26   作者:  
在講這個問題之前,先來補充幾個知識點,如果對此已經(jīng)比較了解可以直接跳過
1. 大多數(shù)游覽器的組件構(gòu)成如圖     


在最底層的三個組件分別是網(wǎng)絡(luò),UI后端和js解釋器。作用如下:
(1)網(wǎng)絡(luò)- 用來完成網(wǎng)絡(luò)調(diào)用,例如http請求,它具有平臺無關(guān)的接口,可以在不同平臺上工作
(2)UI 后端- 用來繪制類似組合選擇框及對話框等基本組件,具有不特定于某個平臺的通用接口,底層使用操作系統(tǒng)的用戶接口
(3)JS解釋器- 用來解釋執(zhí)行JS代碼

ps:上圖和知識點主要來自《HOW BROWSERS WORK: BEHIND THE SCENES OF MODERN WEB BROWSERS》 想深入了解的同學可以重點看下。
2. 大多數(shù)游覽器(比如chrome)讓一個單線程共用于執(zhí)行javascrip和更新用戶界面。這個線程通常被稱為“游覽器UI線程”, 每個時刻只能執(zhí)行其中一種操作,這意味著當Javascript代碼正在執(zhí)行時用戶界面無法響應輸入,反之亦然。這樣做是因為javascript代碼的作用就是操作DOM更新用戶界面,用同一個線程來做負責這兩件事情可以更高效
3. 游覽器UI線程的工作基于一個簡單的隊列系統(tǒng),任務(wù)會被保存到隊列中直到進程空閑。一旦空閑,隊列中的下一個任務(wù)就被重新提取出來并運行。這些任務(wù)要么是運行javascript代碼,要么執(zhí)行UI更新,包括重繪和重排。
4. 重點再強調(diào)下,javascript是單線程運行,千萬別被setTimeout()和setInterVal()這種函數(shù)迷惑而誤以為它是多線程。
ok,基礎(chǔ)點講解完畢,讓我們進入正題,來講解在游覽器中javascript的執(zhí)行過程。
一、原理
一般而言,<script>標簽每次出現(xiàn)都會霸道地讓頁面等待腳本的解析和執(zhí)行,無論當前的Javascript是內(nèi)嵌的還是包含了外鏈文件,頁面的下載和渲染都必須停下來等待腳本執(zhí)行完成。這在頁面的生存周期中是必要的,因為腳本執(zhí)行過程中可能修改頁面內(nèi)容,一個典型的例子就是在頁面中使用document.write()。
當javascript代碼是內(nèi)嵌在html里面時,這點還是比較容易理解,但當javascript是外鏈文件時稍微有點負載,因為存在一個加載過程,而且游覽器加載好這個js文件之后往往還對其緩存。
首先,我們用以下這個例子來說明下緩存問題
復制代碼 代碼如下:

<html>
<head>
<script type='text/javascript' src='js/f2.js'></script>
</head>
<body>
</body>
</html>

第一次打開頁面時:

    第二次打開頁面時:

    從上例中可以明顯看出,像chrome之類的高版本游覽器會對js文件進行緩存,作用是不言而喻,減少網(wǎng)絡(luò)請求。

其次,第二個問題,當一個javascript文件被加載時是否會阻塞其他javascript文件或者其他文件的加載?!陡咝阅躂avascript》一書中對這個問題做了較好的解答:各種游覽器的低版本的處理是當一個javascript文件在加載時,會同時阻塞頁面其他文件的加載(包括其他javascript文件),但IE8,F(xiàn)irfox3.5,Safari 4和Chrome 2都允許并行下載javascript文件,但遺憾的是,javascript下載過程仍然會組舍其他資源的下載,比如圖片。盡管javascript腳本的下載過程不會相互影響,但頁面仍然必須等待所有的javascript代碼下載并執(zhí)行完成才能繼續(xù)。

這里說句題外話:游覽器對同一域名下的并發(fā)鏈接數(shù)也是有限制的,其他一些參數(shù)如下:

二、技巧
1. 腳本位置
由于腳本會阻塞頁面其他資源的下載,因此推薦將所有的<script>標簽放到<body>標簽的底部,已盡量減少對整個頁面下載的影響。
2. 將能合并的js文件合并
3. 無阻塞腳本
現(xiàn)在比較常用的方法就是動態(tài)加載執(zhí)行腳本。你的原理是通過DOM,你幾乎可以用Javascript動態(tài)創(chuàng)建HTML中的所有內(nèi)容,其根本在于,<script>標簽與頁面中其他元素并無差異:都能通過DOM引用,都能在文檔中移動,刪除和創(chuàng)建。文件在改該<script>元素被添加到頁面時開始現(xiàn)在,它不會阻止其他文件下載,只在執(zhí)行階段阻塞渲染。特別強調(diào):《高性能javascript》一文中說“這種技術(shù)的重點在于:無論何時啟動下載,文件的下載和執(zhí)行都不會阻塞頁面其他進程”,這并不是說它在執(zhí)行不會阻塞其他javascript代碼,而是要強調(diào)不會阻塞其他資源的下載等其他任務(wù)。
具體的代碼如下:

復制代碼 代碼如下:

function loadScript(url){
var ga = document.createElement('script');
ga.type = 'text/javascript';
ga.async = true;
ga.src = url;
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(ga);
}

4. 神奇的setTimeout()
這里我不過多的將setTimeout()的原理,有興趣的讀者可以具體去看《高性能javascript》的第六章。我重點強調(diào)下,setTimeout的第二個參數(shù)并不是一個精確的時間,二是必須在javascript線程空閑時才能運行。利用這個特性,如下代碼簡單可以實現(xiàn)等待其他js代碼執(zhí)行完畢后再執(zhí)行function里面的代碼。
復制代碼 代碼如下:

setTimeout(function(){
// do some before other javascripe codes had processed
}, 25)

但在function里面不要使用document.write()方法,因為執(zhí)行setTimeout里面函數(shù)時往往已經(jīng)到了頁面onload之后,此時再執(zhí)行 document.write 將導致當前頁面的內(nèi)容被清空,因為它會自動觸發(fā) document.open 方法。
《高性能Javascript》
HOW BROWSERS WORK: BEHIND THE SCENES OF MODERN WEB BROWSERS
Google Chrome源碼剖析【一】:多線程模型
javascript異步加載詳解

相關(guān)文章

  • 解決layer彈出層的內(nèi)容頁點擊按鈕跳轉(zhuǎn)到新的頁面問題

    解決layer彈出層的內(nèi)容頁點擊按鈕跳轉(zhuǎn)到新的頁面問題

    今天小編就為大家分享一篇解決layer彈出層的內(nèi)容頁點擊按鈕跳轉(zhuǎn)到新的頁面問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • JS快速實現(xiàn)移動端拼圖游戲

    JS快速實現(xiàn)移動端拼圖游戲

    最近開發(fā)一個有關(guān)手機端拼圖游戲,是基于js實現(xiàn)的。今天小編抽時間把具體實現(xiàn)代碼分享到腳本之家平臺供大家參考,對js移動端拼圖游戲感興趣的朋友參考下吧
    2016-09-09
  • 關(guān)于Iframe父頁面與子頁面之間的相互調(diào)用

    關(guān)于Iframe父頁面與子頁面之間的相互調(diào)用

    下面小編就為大家?guī)硪黄P(guān)于Iframe父頁面與子頁面之間的相互調(diào)用。小編覺得挺不錯的,希望對大家有所幫助。一起跟隨小編過來看看吧,祝大家游戲愉快哦
    2016-11-11
  • echarts 3D地圖為區(qū)域自定義顏色的解決方法

    echarts 3D地圖為區(qū)域自定義顏色的解決方法

    在Echarts中,我們很多時候是需要給自己想要的幾個區(qū)域的地圖進行顏色高亮,這篇文章主要給大家介紹了關(guān)于echarts 3D地圖為區(qū)域自定義顏色的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • 使用JavaScript為一張圖片設(shè)置備選路徑的方法

    使用JavaScript為一張圖片設(shè)置備選路徑的方法

    在做網(wǎng)頁開發(fā)的時候,有時候希望給圖片設(shè)置一個備選路徑,即,當src屬性對應的主路徑加載失敗的時候,圖片可以馬上切換到備選路徑,怎么實現(xiàn)呢?下面通過本文給大家分享JavaScript為一張圖片設(shè)置備選路徑的方法,一起看看吧
    2017-01-01
  • ES6 javascript中class類的get與set用法實例分析

    ES6 javascript中class類的get與set用法實例分析

    這篇文章主要介紹了ES6 javascript中class類的get與set用法,結(jié)合具體實例形式分析了ES6中類的get與set關(guān)鍵字使用方法,需要的朋友可以參考下
    2017-10-10
  • 使用JavaScript獲取URL中的參數(shù)(兩種方法)

    使用JavaScript獲取URL中的參數(shù)(兩種方法)

    這篇文章主要介紹了使用JavaScript獲取URL中的參數(shù)(兩種方法)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-11-11
  • uniapp實現(xiàn)地圖點聚合功能的詳細教程

    uniapp實現(xiàn)地圖點聚合功能的詳細教程

    最近公司項目需求需要對設(shè)備在地圖上面進行監(jiān)控,并在當設(shè)備一定距離時進行聚合,這篇文章主要給大家介紹了關(guān)于uniapp實現(xiàn)地圖點聚合功能的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • 使用element-plus時重寫樣式不起作用的問題及解決方法

    使用element-plus時重寫樣式不起作用的問題及解決方法

    這篇文章給大家介紹使用element-plus時重寫樣式不起作用的問題及解決方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-09-09
  • 微信小程序列表中item左滑刪除功能

    微信小程序列表中item左滑刪除功能

    這篇文章主要介紹了微信小程序列表中item左滑刪除功能,本文分步驟給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11

最新評論