首頁 web前端 html教學 HTML頁面載入和解析流程詳細介紹

HTML頁面載入和解析流程詳細介紹

Feb 09, 2017 pm 05:31 PM

瀏覽器載入和渲染html的順序、如何加快HTML頁面載入速度、HTML頁面載入和解析流程等等,在本文將為大家詳細介紹下,有興趣的朋友不要錯過瀏覽器載入和渲染html的順序

1. IE下載的順序是從上到下,渲染的順序也是從上到下,下載和渲染是同時進行的。

2. 在渲染到頁面的某一部分時,其上面的所有部分都已經下載完成(並不是說所有相關聯的元素都已經下載完)。

3. 如果遇到語意解釋性的標籤嵌入檔案(JS腳本,CSS樣式),那麼此時IE的下載過程會啟用單獨連線進行下載。

4. 樣式表在下載完成後,將和先前下載的所有樣式表一起進行解析,解析完成後,將對先前所有元素(含以前已經渲染的)重新進行渲染。

5. JS、CSS中如有重定義,後定義函數將覆蓋前定義函數。

JS的載入

1. 不能並行下載和解析(阻塞下載)。

2. 當引用了JS的時候,瀏覽器發送1個js request就會一直等待該request的回傳。因為瀏覽器需要1個穩定的DOM樹結構,而JS中很有可能有

程式碼直接改變了DOM樹結構,例如使用document.write 或appendChild,甚至是直接使用的location.href進行跳轉,瀏覽器為了防止出現JS修

改DOM樹,需要重新構建DOM樹的情況,所以就會阻塞其他的下載和呈現.

如何加快HTML頁面加載速度

1. 頁面減肥:

. 頁面的肥瘦是影響載入速度最重要的因素。

b. 刪除不必要的空格、註解。

c. 將inline的script和css移到外部檔案。

d. 可以使用HTML Tidy來為HTML減肥,也可以使用一些壓縮工具來為JavaScript減肥。

2. 減少檔案數量:

a. 減少頁面上引用的檔案數量可以減少HTTP連線數。

b. 許多JavaScript、CSS檔案可以合併最好合併,人家財幫子都把自己的JavaScript. functions和Prototype.js合併到一個base.js檔案裡去了。

3. 減少網域名稱查詢:

a. DNS查詢和解析網域名稱也是消耗時間的,所以要減少外部JavaScript、CSS、圖片等資源的引用,不同網域的使用越少越好。

4. 快取重用資料:

a. 將重複使用的資料快取。

5. 最佳化頁面元素載入順序:

a. 首先載入頁面最初顯示的內容和與之相關的JavaScript和CSS,然後載入HTML相關的東西,像什麼不是最初顯示相關的圖片、flash、影片等很肥的資源就最後加載。

6. 減少inline JavaScript的數量:

a. 瀏覽器parser會假設inline JavaScript會改變頁面結構,所以使用inline JavaScript開銷較大。

b. 不要使用document.write()這種輸出內容的方法,使用現代W3C DOM方法來為現代瀏覽器處理頁面內容。

7. 使用現代CSS和合法的標籤:

a. 使用現代CSS來減少標籤和圖像,例如使用現代CSS+文字完全可以替代一些只有文字的圖片。

b. 使用合法的標籤避免瀏覽器解析HTML時做「error correction」等操作,也可以被HTML Tidy來為HTML減肥。

8. Chunk your content:

a. 不要使用巢狀table,而使用非巢狀table或p。將基於大塊巢狀的table的layout分解成多個小table,這樣就不需要等到整個頁面(或大table)內容全部載入完才顯示。

9. 指定圖像和table的大小:

a. 如果瀏覽器可以立即決定圖像或table的大小,那麼它就可以馬上顯示頁面而不要重新做一些佈局安排的工作。

b. 這不僅加快了頁面的顯示,也預防了頁面完成載入後佈局的一些不當的改變。

c. image使用height和width。

HTML頁面載入和解析流程

1. 使用者輸入網址(假設是個html頁面,並且是第一次造訪),瀏覽器向伺服器發出請求,伺服器傳回html檔。

2. 瀏覽器開始載入html程式碼,發現

標籤內有一個標籤引用外部CSS檔案。

3. 瀏覽器又發出CSS檔案的請求,伺服器回傳這個CSS檔案。

4. 瀏覽器繼續載入html中部分的程式碼,並且CSS檔案已經拿到手了,可以開始渲染頁面了。

5. 瀏覽器在程式碼中發現一個HTML頁面載入和解析流程詳細介紹標籤引用了一張圖片,向伺服器發出請求。此時瀏覽器不會等到圖片下載完,而是繼續渲染後面的程式碼。

6. 伺服器傳回圖片文件,由於圖片佔據了一定面積,影響了後面段落的排布,因此瀏覽器需要回過頭來重新渲染這部分程式碼。

7. 瀏覽器發現了一個包含一行Javascript程式碼的<script>標籤,趕快執行它。 <br/><br/>8. Javascript腳本執行了這條語句,它命令瀏覽器隱藏掉程式碼中的某個<style>(style.display=”none”)。杯具啊,突然就少了這麼一個元素,瀏覽器不得不重新渲染這部分程式碼。 <br/><br/>9. 終於等到了的到來,瀏覽器淚流滿面… <br/><br/>10. 等等,還沒完,用戶點了一下介面中的「換膚」按鈕,Javascript讓瀏覽器換了一下<link>標籤的CSS路徑。 <br/><br/>11. 瀏覽器召集了在座的各位<p><span><ul><li>們,“大夥兒收拾收拾行李,咱得重新來過……”,瀏覽器向服務器請求了新的CSS文件,重新渲染頁面。 <p>更多HTML頁面載入與解析流程詳細介紹相關文章請關注PHP中文網! </script>
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

&gt; gt;的目的是什麼 元素? &gt; gt;的目的是什麼 元素? Mar 21, 2025 pm 12:34 PM

本文討論了HTML&lt; Progress&gt;元素,其目的,樣式和與&lt; meter&gt;元素。主要重點是使用&lt; progress&gt;為了完成任務和LT;儀表&gt;對於stati

&lt; datalist&gt;的目的是什麼。 元素? &lt; datalist&gt;的目的是什麼。 元素? Mar 21, 2025 pm 12:33 PM

本文討論了html&lt; datalist&gt;元素,通過提供自動完整建議,改善用戶體驗並減少錯誤來增強表格。Character計數:159

HTML5中跨瀏覽器兼容性的最佳實踐是什麼? HTML5中跨瀏覽器兼容性的最佳實踐是什麼? Mar 17, 2025 pm 12:20 PM

文章討論了確保HTML5跨瀏覽器兼容性的最佳實踐,重點是特徵檢測,進行性增強和測試方法。

&lt; meter&gt;的目的是什麼。 元素? &lt; meter&gt;的目的是什麼。 元素? Mar 21, 2025 pm 12:35 PM

本文討論了HTML&lt; meter&gt;元素,用於在一個範圍內顯示標量或分數值及其在Web開發中的常見應用。它區分了&lt; meter&gt;從&lt; progress&gt;和前

如何使用HTML5表單驗證屬性來驗證用戶輸入? 如何使用HTML5表單驗證屬性來驗證用戶輸入? Mar 17, 2025 pm 12:27 PM

本文討論了使用HTML5表單驗證屬性,例如必需的,圖案,最小,最大和長度限制,以直接在瀏覽器中驗證用戶輸入。

視口元標籤是什麼?為什麼對響應式設計很重要? 視口元標籤是什麼?為什麼對響應式設計很重要? Mar 20, 2025 pm 05:56 PM

本文討論了視口元標籤,這對於移動設備上的響應式Web設計至關重要。它解釋瞭如何正確使用確保最佳的內容縮放和用戶交互,而濫用可能會導致設計和可訪問性問題。

&lt; iframe&gt;的目的是什麼。 標籤?使用時的安全考慮是什麼? &lt; iframe&gt;的目的是什麼。 標籤?使用時的安全考慮是什麼? Mar 20, 2025 pm 06:05 PM

本文討論了&lt; iframe&gt;將外部內容嵌入網頁,其常見用途,安全風險以及諸如對象標籤和API等替代方案的目的。

Gitee Pages靜態網站部署失敗:單個文件404錯誤如何排查和解決? Gitee Pages靜態網站部署失敗:單個文件404錯誤如何排查和解決? Apr 04, 2025 pm 11:54 PM

GiteePages靜態網站部署失敗:404錯誤排查與解決在使用Gitee...

See all articles