2022-05-29 分類(lèi): 網(wǎng)站建設(shè)
瀏覽器的主要功能是將用戶(hù)選擇的web資源呈現(xiàn)出來(lái),它從服務(wù)器請(qǐng)求資源,并將得到的資源(HTML,PDF,image等等)顯示在瀏覽器窗口。那么從用戶(hù)敲入U(xiǎn)RL到完整渲染出來(lái),經(jīng)歷了什么過(guò)程呢?也就是說(shuō)整個(gè)瀏覽器的工作流程是怎樣的呢?
整個(gè)過(guò)程大致如下:
6. 瀏覽器發(fā)送請(qǐng)求,以獲取嵌入在HTML中的對(duì)象。在瀏覽器顯示HTML時(shí),它會(huì)注意到需要獲取其他地址內(nèi)容的標(biāo)簽。
這時(shí),瀏覽器會(huì)發(fā)送一個(gè)獲取請(qǐng)求來(lái)重新獲得這些文件——包括CSS/JS/圖片等資源,這些資源的地址都要經(jīng)歷一個(gè)和HTML讀取類(lèi)似的過(guò)程。所以瀏覽器會(huì)在DNS中查找這些域名,發(fā)送請(qǐng)求,重定向等等…
那么,一個(gè)頁(yè)面,究竟是如何從我們輸入一個(gè)網(wǎng)址到最后完整的呈現(xiàn)在我們面前的呢?還需要了解一下瀏覽器是如何渲染的。html解析過(guò)程:01機(jī)器碼-》charter字符-》tokens令牌-》node節(jié)點(diǎn)-》dom樹(shù)
因?yàn)闉g覽器解析文檔,如果遇到請(qǐng)求外部資源時(shí),如圖像,iconfont,JS等。瀏覽器將下載該資源。請(qǐng)求過(guò)程是異步的,并不會(huì)影響HTML文檔進(jìn)行加載,當(dāng)遇到