成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

借助performance工具直觀理解瀏覽器的渲染過程

GT / 2916人閱讀

前言

在學(xué)習(xí)前端的過程中,大家都會對瀏覽器這個神秘的盒子感到好奇
從輸入一串url到頁面解析渲染完成,瀏覽器都干了些啥?

直觀展示

為了更好的理解這個過程,我們使用一個工具來幫助我們
Chrome自帶的開發(fā)工具中的performance(老版本和其他瀏覽器為timeline

點擊錄制,然后在地址欄輸入我們的url
這里以百度為例,輸入www.baidu.com,回車
然后點擊錄制結(jié)束,就能看到這個東西

網(wǎng)絡(luò)請求

我們最先看到的是這個

字面意思就可以理解,瀏覽器在向服務(wù)器發(fā)送請求,并接收響應(yīng)頭和響應(yīng)體
不過實際上在這之前,瀏覽器還做了一些事
得先知道朝哪個服務(wù)器發(fā)送請求吧

根據(jù)url,先去本地DNS緩存列表里尋找對應(yīng)的服務(wù)器的ip地址和端口號,若沒有找到,繼續(xù)尋找系統(tǒng)緩存和路由緩存,若找到則跳轉(zhuǎn)第三步

還沒找到的話則請求本地DNS服務(wù)器,沒有就將域名發(fā)送給其他服務(wù)器,遞歸尋找,從根域名服務(wù)器開始不斷向下遞歸,直到返回對應(yīng)的IP地址和端口號,并將其緩存

根據(jù)ip地址和端口號,與目標服務(wù)器建立TCP連接(三次握手)

這三步并沒有被我們看見,然后接下來的事就被我們觀察到了
瀏覽器向服務(wù)器發(fā)送http請求,并接收返回的響應(yīng)頭和響應(yīng)體

繼續(xù)往下看


黃色部分都是瀏覽器的一些默認行為,其中包括隱藏本來的標簽頁內(nèi)容等等
以及下面的Recalculate Style(重新計算樣式),Layout(重排)是為清空本來的頁面,為新頁面做準備
這些不用管它,不過在這中間我們又一次看到了Receive Data
那是因為服務(wù)器在發(fā)送數(shù)據(jù)的時候,可能會進行拆包,分幾次發(fā)送

解析html

瀏覽器比較勤快,它并不會等html完全接收完才開始解析,而是接受一部分就開始解析一部分

HTML Parser的任務(wù)是將HTML標記,解析成DOM Tree,這是一個深度遍歷的過程,只有Dom下的子節(jié)點都被遍歷完成,才遍歷下一個同級Dom節(jié)點


同時,在解析的過程中,如果遇到了圖片,link標簽,script標簽,都會向服務(wù)器發(fā)送請求
例如我們上圖,遇到了百度的logo圖片,就請求下載

js解析


遇到js就立即解析下載執(zhí)行執(zhí)行


不管是內(nèi)聯(lián)的還是外部的,都會阻塞后續(xù)dom的解析和渲染
所以一般將

外部的css文件,則在接收到了之后進行解析

兩者都會不會阻塞Dom的解析,但會阻塞Dom的渲染
這也是為什么要把css標簽放進

當css文件放在中時,雖然css解析也會阻塞后續(xù)dom的渲染,但是在解析css的同時也在解析dom,所以等到css解析完畢就會逐步的渲染頁面了

css語句解析成為CSSOM

渲染布局與繪制

在有了Dom TreeCSSOM之后
瀏覽器就會構(gòu)建Render Tree(渲染樹)

其實把DOM Tree和CSSOM進行附加

所以Render Tree實際上就是一個計算好了樣式,同時不包含display:none之類,不占據(jù)空間的元素的的渲染樹。
然后瀏覽器就根據(jù)這個Render Tree進行第一次的布局(Layout)以及繪制(Paint

重排和重繪

完成了第一次繪制之后,瀏覽器會繼續(xù)收到服務(wù)器發(fā)來的數(shù)據(jù)
圖片,css文件,js文件
其中可能會有導(dǎo)致頁面布局更改或樣式更改的內(nèi)容,都會添加到我們的Render Tree上去
引起重排(Layout)或重繪(Paint

其中重排一定會連帶著引起重繪,反之則不然

重排(Reflow)

引起重排的操作

頁面首次渲染 
瀏覽器窗口大小發(fā)生改變
元素尺寸或位置發(fā)生改變
元素內(nèi)容變化(文字數(shù)量或圖片大小等等)
元素字體大小變化
添加或者刪除可見的DOM元素
激活CSS偽類(例如::hover)
設(shè)置style屬性

那是遇到一次就重排一次嗎?也不是
瀏覽器會有一個渲染隊列來進行優(yōu)化
積累了一定量或一定時間的更改內(nèi)容,才會進行重排

不過當訪問了特定屬性的時候
比如js文件里遇到一句console.log(body.clientWidth)
會強制刷新渲染隊列
以下屬性的訪問會立即刷新渲染隊列

widthheight margin padding display border
position overflow clientWidth clientHeight clientTop
clientLeft offsetWidth offsetHeight offsetTop offsetLeft
scrollWidth scrollHeight scrollTop scrollLeft scrollIntoView()
scrollTo() getComputedStyle() getBoundingClientRect() scrollIntoViewIfNeeded()

所以訪問這些屬性要謹慎,最好分離讀寫,以免過多的重排影響性能

重繪

引起重繪的一般都是修改元素的屬性

color border-style visibility background
text-decoration background-image background-position background-repeat
outline-color outline outline-style border-radius
outline-width box-shadow background-size
性能優(yōu)化

從性能優(yōu)化的角度,我們要盡量減少瀏覽器的重排和重繪,尤其是重排

盡量不要在布局信息改變時做查詢(會導(dǎo)致渲染隊列強制刷新)

減少DOM操作,同一個DOM的多個屬性改變可以寫在一起,在一個局部方法中需要多次訪問同一個Dom,則先暫存它的引用。批量添加DOM,可以先讓元素脫離文檔流,操作完后再帶入文檔流,這樣只會觸發(fā)一次重排(應(yīng)用fragment元素)

將需要多次重排的元素,position屬性設(shè)為absolutefixed,例如有動畫效果的元素

采用更優(yōu)的API替代消費高的API,轉(zhuǎn)換優(yōu)化消費高的集合,如用querySelectorAll()替代getElementByXX()。

開啟動畫的GPU加速

少用HTML集合(類數(shù)組)來遍歷,因為集合遍歷比真數(shù)組遍歷耗費更高。

用事件委托來減少事件處理器的數(shù)量。

避免設(shè)置大量的style屬性,因為通過每一次設(shè)置都會觸發(fā)一次reflow,所以最好是使用class屬性

動畫實現(xiàn)的速度太精細平滑,會導(dǎo)致reflow過于頻繁

不要使用table布局,因為table中某個元素旦觸發(fā)了reflow,那么整個表格都會reflow??梢栽O(shè)置table-layout:auto;或者是table-layout:fixed這樣可以只reflow一行,

減少通過JavaScript代碼修改元素樣式,盡量使用修改class名方式操作樣式或動畫;

隱藏在屏幕外,或在頁面滾動時,盡量停止動畫;

最后

大家可以自己去嘗試一下performance的使用,可以更直觀的理解瀏覽器的工作流程

參考文章

https://segmentfault.com/a/11...
https://segmentfault.com/a/11...
https://sylvanassun.github.io...
https://www.imooc.com/article...
https://segmentfault.com/a/11...

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/55022.html

相關(guān)文章

  • 借助performance工具直觀理解覽器渲染過程

    前言 在學(xué)習(xí)前端的過程中,大家都會對瀏覽器這個神秘的盒子感到好奇從輸入一串url到頁面解析渲染完成,瀏覽器都干了些啥? 直觀展示 為了更好的理解這個過程,我們使用一個工具來幫助我們Chrome自帶的開發(fā)工具中的performance(老版本和其他瀏覽器為timeline) showImg(https://segmentfault.com/img/bVbswbe?w=1338&h=920); 點擊錄...

    Pikachu 評論0 收藏0
  • 借助performance工具直觀理解覽器渲染過程

    前言 在學(xué)習(xí)前端的過程中,大家都會對瀏覽器這個神秘的盒子感到好奇從輸入一串url到頁面解析渲染完成,瀏覽器都干了些啥? 直觀展示 為了更好的理解這個過程,我們使用一個工具來幫助我們Chrome自帶的開發(fā)工具中的performance(老版本和其他瀏覽器為timeline) showImg(https://segmentfault.com/img/bVbswbe?w=1338&h=920); 點擊錄...

    王巖威 評論0 收藏0
  • 前端性能優(yōu)化之Performance神器

    摘要:需要注意的一點是,面板下的功能,是對于細節(jié)中的細節(jié)進行的優(yōu)化。我們可以很清晰明了得分析按照活動,目錄,域,子域,和進行分組的前端性能。個人理解的話,前者類似事件冒泡,后者類似事件捕獲。同學(xué)在點我達,他們正在籌劃改組成大前端團隊。   對Chrome控制臺有一定的了解的朋友都在知道,Network面板會包括很多網(wǎng)絡(luò)請求方面的東西,包括Http相關(guān)的Request信息,Response信息...

    qujian 評論0 收藏0
  • 硬件加速

    摘要:但硬件加速是把雙刃劍,過渡的使用硬件加速會適得其反。所以,一定要牢記不要讓頁面的每個元素都使用硬件加速,當且僅當需要的時候才為元素創(chuàng)建渲染層。參考文檔無線性能優(yōu)化動畫及硬件加速高性能動畫與頁面渲染渲染優(yōu)化層模型 前言 談起瀏覽器的硬件加速,想必大家都知道的一個技巧就是在用CSS3做動畫時,給元素添加transform: translateZ(0)或者transform: transla...

    mo0n1andin 評論0 收藏0
  • 硬件加速

    摘要:但硬件加速是把雙刃劍,過渡的使用硬件加速會適得其反。所以,一定要牢記不要讓頁面的每個元素都使用硬件加速,當且僅當需要的時候才為元素創(chuàng)建渲染層。參考文檔無線性能優(yōu)化動畫及硬件加速高性能動畫與頁面渲染渲染優(yōu)化層模型 前言 談起瀏覽器的硬件加速,想必大家都知道的一個技巧就是在用CSS3做動畫時,給元素添加transform: translateZ(0)或者transform: transla...

    xiaotianyi 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<