真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ChromeDevTools中如何啟動Performance

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)Chrome DevTools中如何啟動Performance,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

創(chuàng)新互聯(lián)是一家網(wǎng)站設(shè)計公司,集創(chuàng)意、互聯(lián)網(wǎng)應(yīng)用、軟件技術(shù)為一體的創(chuàng)意網(wǎng)站建設(shè)服務(wù)商,主營產(chǎn)品:響應(yīng)式網(wǎng)站設(shè)計、品牌網(wǎng)站設(shè)計、全網(wǎng)營銷推廣。我們專注企業(yè)品牌在網(wǎng)站中的整體樹立,網(wǎng)絡(luò)互動的體驗,以及在手機(jī)等移動端的優(yōu)質(zhì)呈現(xiàn)。網(wǎng)站設(shè)計制作、成都做網(wǎng)站、移動互聯(lián)產(chǎn)品、網(wǎng)絡(luò)運(yùn)營、VI設(shè)計、云產(chǎn)品.運(yùn)維為核心業(yè)務(wù)。為用戶提供一站式解決方案,我們深知市場的競爭激烈,認(rèn)真對待每位客戶,為客戶提供賞析悅目的作品,網(wǎng)站的價值服務(wù)。

今天介紹下 Chrome dev tools 家族的一個小兄弟,它在 Chrome 57 之前叫作「Timeline」,而現(xiàn)在換了個更長的馬甲 —— 「Performance」,畢竟名字要「長~~~~~~~~~」更能吸引注意。

也許你曾不經(jīng)意啟動過這個工具,看見里面五顏六色的圖表后和我一樣頭暈?zāi)垦?。但今天介紹完它后,我相信你能像熟悉瑞士軍刀一樣熟悉它。

這個面板叫做「Performance」,不過名字里也沒有指明是什么性能。既然是 Chrome 的調(diào)試工具,那應(yīng)該和頁面有關(guān)系,我們就從頁面性能聊起。

什么會影響你的頁面性能

近年來,WEB 開發(fā)者們?yōu)榭s短用戶等待時間做出了一系列方案,以期「短益求短」。比如用 PWA 緩存更多可用的離線資源,讓網(wǎng)頁應(yīng)用打開更快;借助 WebAssembly 規(guī)范縮小資源體積,提高執(zhí)行效率。這些方案分別著眼于網(wǎng)絡(luò)鏈路,前端資源處理速度等維度上,致力提高用戶體驗。

作為 WEB 開發(fā)者,我感受到跟頁面性能掛鉤比較深的幾個維度是:網(wǎng)絡(luò)鏈路、服務(wù)器資源、前端資源渲染效率、用戶端硬件。

網(wǎng)絡(luò)鏈路

網(wǎng)絡(luò)鏈路往往是頁面性能的扼要之處,域名解析、交換機(jī)、路由器、網(wǎng)絡(luò)服務(wù)提供商、內(nèi)容分發(fā)網(wǎng)絡(luò)、服務(wù)器,鏈路上的節(jié)點(diǎn)出問題或響應(yīng)過慢都會有不好的體驗。

服務(wù)器資源

在 HTTP 的大環(huán)境下,所有請求最終都要服務(wù)器來處理,服務(wù)器爸爸處理不當(dāng)無法響應(yīng)或響應(yīng)過慢也會直接影響頁面與用戶的互動。

前端資源渲染

瀏覽器獲取所需 HTML、CSS、腳本、圖片等靜態(tài)資源,繪制首屏呈現(xiàn)給用戶的過程;或用戶與頁面交互后,瀏覽器重新計算需要呈現(xiàn)的內(nèi)容,然后重新繪制的過程。這些過程的處理效率也是影響性能的重要因素。

用戶硬件

發(fā)起網(wǎng)絡(luò)請求,解析網(wǎng)絡(luò)響應(yīng),頁面渲染繪制等過程都需要消耗計算機(jī)硬件資源。所以計算機(jī)資源,特別是 CPU 和 GPU 資源短缺時(比如打顯卡殺手類的游戲),也會影響頁面性能。

當(dāng)然,以上的維度不是劃線而治的,它們更多是犬牙交錯的關(guān)系。例如在渲染過程中瀏覽器反應(yīng)很慢,有可能是腳本寫得太爛遭遇性能瓶頸,也有可能是顯卡殺手游戲占用了過多計算機(jī)資源;又如在分析前端資源渲染時,往往要結(jié)合網(wǎng)絡(luò)瀑布圖分析資源的獲取時間,因為渲染頁也是個動態(tài)的過程,有些關(guān)鍵資源需要等待,有些則可以在渲染的同時加載。

為什么祭出 Performance

Chrome 的開發(fā)者工具各有自己的側(cè)重點(diǎn),如 Network 工具的瀑布圖有著資源拉取順序的詳細(xì)信息,它的側(cè)重點(diǎn)在于分析網(wǎng)路鏈路。而 Performance 工具的側(cè)重點(diǎn)則在于前端渲染過程,它擁有幀率條形圖、CPU 使用率面積圖、資源瀑布圖、主線程火焰圖、事件總覽等模塊,它們和渲染息息相關(guān),善用它們可以清晰地觀察整個渲染階段。不過,你不必糾結(jié)上面提到的模塊名,因為在接下來的篇幅里,我會一一介紹他們。

用正確的姿勢啟動 Performance

打開 Performance

首先我們打開 Chrome 匿名窗口,在匿名環(huán)境下,瀏覽器不會有額外的插件、用戶特性、緩存等影響實驗可重復(fù)性的因素。接著啟動開發(fā)者工具,如果你的窗口寬度足夠,可以在頂端標(biāo)簽欄的第 5 欄看到 Performance,寬度不夠則可以通過右上的 >> 按鈕點(diǎn)開更多標(biāo)簽,找到它。

Chrome DevTools中如何啟動Performance

此時我們看到的是 Performance 的默認(rèn)引導(dǎo)頁面。其中第一句提示語所對應(yīng)的操作是立即開始記錄當(dāng)前頁面發(fā)生的所有事件,點(diǎn)擊停止按鈕才會停止記錄。第二句對應(yīng)的操作則是重載頁面并記錄事件,工具會自動在頁面加載完畢處于可交互狀態(tài)時停止記錄,兩者最終都會生成報告(生成報告需要大量運(yùn)算,會花費(fèi)一些時間)。

Chrome DevTools中如何啟動Performance

現(xiàn)在,工具已準(zhǔn)備好,可以開始分析頁面了。

簡單頁面分析

首先我們分析一個簡單頁面從空白頁面到渲染完畢的過程。本文所有示例頁面都放在下面的倉庫里,通過命令克隆并切換到倉庫根目錄:

git clone git@github.com:pobusama/chrome-preformance-use-demo.git && cd chrome-preformance-use-demo

接著安裝依賴包:npm i

最后啟動示例頁面:npm run demo1

Chrome DevTools中如何啟動Performance

由于很難把握頁面開始渲染的時機(jī),我們通過第二種 reload 方式收集渲染數(shù)據(jù),將 beforeunload -> unload -> Send Request(第一個資源請求) -> load 的過程都記錄下來。

在工具自動停止記錄后,我們得到了這樣一份報告:

Chrome DevTools中如何啟動Performance

圖中劃出的 4 個區(qū)域分別是:

1:控制面板,用來控制工具的特性。「Network」與「CPU」:分別限制網(wǎng)絡(luò)和計算資源,模擬不同終端環(huán)境,可以更容易觀測到性能瓶頸?!窪isable JavaScript samples」選項開啟會使工具忽略記錄 JS 的調(diào)用棧,這個我們之后會再提到。打開「Enable advanced paint instrumentation」則會詳細(xì)記錄某些渲染事件的細(xì)節(jié),這個功能我們在了解這些事件后再聊。

2:概覽面板,其中有描述幀率(FPS)、CPU 使用率、網(wǎng)絡(luò)資源情況的 3 個圖表。幀率是描繪每秒鐘渲染多少幀圖像的指標(biāo),幀率越高則在觀感上更流暢。網(wǎng)絡(luò)情況是以瀑布圖的形式呈現(xiàn),圖中可以觀察到各資源的加載時間與順序。CPU 使用率面積圖的其實是一張連續(xù)的堆積柱狀圖(下面 CPU 面積圖放大版為示意圖,數(shù)據(jù)非嚴(yán)謹(jǐn)對應(yīng)):

Chrome DevTools中如何啟動Performance

其縱軸是 CPU 使用率,橫軸是時間,不同的顏色代表著不同的事件類型,其中:

  • 藍(lán)色:加載(Loading)事件

  • 黃色:腳本運(yùn)算(Scripting)事件

  • 紫色:渲染(Rendering)事件

  • 綠色:繪制(Painting)事件

  • 灰色:其他(Other)

  • 閑置:瀏覽器空閑

舉例來說,示意圖的第一列:總 CPU 使用率為 18,加載事件(藍(lán)色)和腳本運(yùn)算事件(黃色)各占了一半(9)。隨著時間增加,腳本運(yùn)算事件的 CPU 使用率逐漸增加,而加載事件的使用率在 600ms 左右降為 0;另一方面渲染事件(紫色)的使用率先升后降,在 1100ms 左右降為 0。整張圖可以清晰地體現(xiàn)哪個時間段什么事件占據(jù) CPU 多少比例的使用率。

Chrome DevTools中如何啟動Performance

3:線程面板,用以觀察細(xì)節(jié)事件,在概覽面板縮小觀察范圍可以看到線程圖的細(xì)節(jié)。其中主線程火焰圖是用來分析渲染性能的主要圖表。不同于「正?!够鹧鎴D,這里展示的火焰圖是倒置的,即最上層是父級函數(shù)或應(yīng)用,越往下則調(diào)用棧越淺,最底層的一小格(如果時間維度拉得不夠長,看起來像是一小豎線)表示的是函數(shù)調(diào)用棧頂層。

默認(rèn)情況下火焰圖會記錄已執(zhí)行 JS 程序調(diào)用棧中的每層函數(shù)(精確到單個函數(shù)的粒度),非常詳細(xì)。而開啟「Disable JS Samples」后,火焰圖只會精確到事件級別(調(diào)用某個 JS 文件中的函數(shù)是一個事件),忽略該事件下的所有 JS 函數(shù)調(diào)用棧。

Chrome DevTools中如何啟動Performance

此外,幀線程時序圖(Frames)和網(wǎng)絡(luò)瀑布圖(Network)可以從時間維度分別查看繪制出的頁面和資源加載情況。

Chrome DevTools中如何啟動Performance

4:詳情面板。前面已經(jīng)多次提到事件,我想如果再不解釋可能要被寄刀片了。Performance 工具中,所有的記錄的最細(xì)粒度就是事件。這里的事件不是指 JS 中的事件,而是一個抽象概念,我們打開主線程火焰圖,隨意點(diǎn)擊一個方塊,就可以在詳情面板里看到該事件的詳情,包括事件名、事件耗時、發(fā)起者等信息。舉幾個例子:Parse HTML 是一種 Loading 事件(藍(lán)色),它表示在在事件時間內(nèi),Chrome 正在執(zhí)行其 HTML 解析算法;Event 是一種 Scripting 事件(黃色),它表示正在執(zhí)行 JS 事件(例如 click);Paint 是一種繪制事件(綠色),表示 Chrome 將合成的圖層繪制出來。

Chrome DevTools中如何啟動Performance

以下是一些常見事件,有個印象就好,由于每次做性能分析必會跟它們打交道,我們想不記住他們也難。

Chrome DevTools中如何啟動Performance

詳情面板還有非常重要的一部分就是事件耗時餅狀圖,它列出了你選擇的時間段內(nèi),不同類型事件(加載、腳本運(yùn)算、渲染、繪制、其他事件、發(fā)呆:) )所占的比例和耗費(fèi)的時間。分析耗時占比與分析 CPU 面積圖有相通的意義 —— 到底是哪種事件消耗了大量算力和時間,導(dǎo)致了性能瓶頸。

Chrome DevTools中如何啟動Performance

至此,我們掃了一遍 Performance 工具的主要功能,雖然沒有面面俱到,但足以開啟性能分析之旅。接下來我們分析一個稍微復(fù)雜些的動畫頁面,真正理解使用這些圖表數(shù)據(jù)如何定位性能問題。

嘮叨一下瀏覽器渲染過程

知曉瀏覽器的渲染過程對我們理解分析十分重要,這里簡要介紹一下瀏覽器渲染的過程:

Chrome DevTools中如何啟動Performance

當(dāng)渲染首屏?xí)r,瀏覽器分別解析 HTML 與 CSS 文件,生成文檔對象模型(DOM)與 樣式表對象模型(CSSOM);合并 DOM 與 CSSOM 成為渲染樹(Render Tree);計算樣式( Style);計算每個節(jié)點(diǎn)在屏幕中的精確位置與大?。↙ayout);將渲染樹按照上一步計算出的位置繪制到圖層上(Paint);渲染引擎合成所有圖層最終使人眼可見(Composite Layers)。

如果改變頁面布局,則是先通過 JS 更新 DOM 再經(jīng)歷計算樣式到合成圖像這個過程。如果僅僅是非幾何變化(顏色、visibility、transform),則可以跳過布局步驟。

動畫分析

有了上面這些準(zhǔn)備,相信你已開始摩拳擦掌了。我們在示例倉庫下跑另外一個 Demo:cd chrome-preformance-use-demo && npm run demo2

Chrome DevTools中如何啟動Performance

初始狀態(tài)下,10個小方塊會分別上下勻速運(yùn)動,碰到瀏覽器邊界后原路返回?!窤dd 10」是增加 10 個這樣的小方塊,「Substract 10」是減少 10 個,「Stop/Start」暫停/開啟所有小方塊的運(yùn)動,「Optimize/Unoptimize」優(yōu)化/取消優(yōu)化動畫。

瀏覽器是怎么繪制一幀動畫的

在默認(rèn)狀態(tài)下,我們點(diǎn)擊左上角的圓記錄事件,幾秒后我們可以點(diǎn)擊 Performance 中的 Stop 產(chǎn)生分析數(shù)據(jù)。在概覽面板中我們看到在渡過最初的幾百毫秒后,CPU 面積圖中各種事件占比按固定周期變化,我們點(diǎn)取其中一小段觀察,在主線程圖中可看到一段一段類似事件組。觀察幾組事件后,我們發(fā)現(xiàn),這些事件組的組成都是:10 個 Recalculate Style + Layout 的循環(huán) -> Update Layer Tree -> Paint -> Composite Layers。我們知道,Composite Layers 事件之后,意味著人眼可見新的頁面圖層,也就是說這樣一組事件過后,一幀畫面繪制在眼前。

Chrome DevTools中如何啟動Performance

我們點(diǎn)開主線程火焰圖的上一欄「Framse」,發(fā)現(xiàn) Composite Layers 事件后不久的虛線處就是下一幀畫面出現(xiàn)的節(jié)點(diǎn),這側(cè)面證實了上面的結(jié)論。

Chrome DevTools中如何啟動Performance

當(dāng)瓶頸出現(xiàn)時

目前的動畫看著沒什么毛病,我們點(diǎn)擊 20 次「Add 10」按鈕,增加方塊數(shù),可以看到動畫出現(xiàn)了明顯的卡頓,如果還不感覺卡頓,說明你的計算機(jī)性能已經(jīng)擊敗了全國 99% 的用戶(或者,呃...你可能要去醫(yī)院看眼睛了),這時你可以在控制面板里降低 CPU 算力。好了,我們再次記錄性能數(shù)據(jù):

Chrome DevTools中如何啟動Performance

我們看到報告中有多處醒目的紅色,包括幀率圖上的大紅杠、主線程圖中的小角標(biāo)。

再次按照之前的思路,查看主線程的細(xì)節(jié),我們發(fā)現(xiàn)在 app.update 函數(shù)下發(fā)生的 Recalculate Style 和 Layout 事件都出現(xiàn)了警告,提示性能瓶頸的原因可能是強(qiáng)制重排。進(jìn)入 js 文件查看詳細(xì)代碼,在左欄可以看到消耗了大量時間的代碼行呈深黃色,那么這些代碼就很有可能是癥結(jié)所在。

Chrome DevTools中如何啟動Performance

注意:自動計算代碼行運(yùn)算時間需要取消勾選控制面版的「Disable JavaScript Samples」選項。

那么,這行代碼到底有什么問題呢,重排又是什么呢?

再談重排與重繪

簡而言之,重排(reflow)和重繪(repaint)都是改變頁面樣式的步驟。重排步驟包括 Recalculate Style、Layout、Update Layer Tree 等渲染類型事件,重繪步驟包括 Paint 和 Composite Layers 這些繪制類型事件。重排之后必然會造成重繪,而造成重繪的操作不一定會造成重排。下面列出了一些造成重排或重繪的常見操作,更多操作可以參閱 csstriggers

Chrome DevTools中如何啟動Performance

由于計算布局需要大量時間,重排的開銷遠(yuǎn)大于重繪,在達(dá)到相同效果的情況下,我們需要盡量避免重排。舉個例子,如果 display: none 和 visibility: hidden 都能滿足需求,那么后者更優(yōu)。

解決瓶頸

再回頭看一下我們的動畫 Demo,在 performance 的詳情面板中,餅圖顯示動畫的繪制過程中渲染(重排)占據(jù)的大部分的比重,結(jié)合代碼我們發(fā)現(xiàn)原因:循環(huán)中多次在剛給 DOM 更新樣式位置后,立即通過 offsetTop 獲取 DOM 位置。這樣的操作會強(qiáng)制啟動重排,因為瀏覽器并不清楚上一個循環(huán)內(nèi) DOM 有沒有改變位置,必須立即重新布局才能計算 DOM 位置。別急,你可能已經(jīng)注意到了,我們還有一個「Optimize」按鈕。

針對這個問題,我們的優(yōu)化方案是將 offsetTop 替換成 style.top,后者雖然取的是上一幀動畫的元素位置,但并不影響計算下一幀動畫位置,省去了重排獲取位置的過程,減少了不必要的重排。

注意:本示例中,還有一處優(yōu)化是非 Optimize 的情況下就做了的,就是通過   requestAnimationFrame  函數(shù)將一幀循環(huán)內(nèi)所有的樣式改動( m.style.top = pos + 'px';)累計在下一次繪制時統(tǒng)一處理。這樣做除了優(yōu)化了樣式的寫操作,還讓我們更清楚地觀察到 offsetTop 讀操作這個問題的現(xiàn)象。

我們對比一下優(yōu)化前后的報告:

Chrome DevTools中如何啟動Performance

首先從餅圖和 CPU 面積圖看,Rendering 事件占比下滑,Painting 事件占比上升。而從幀率圖和 frames 線程圖中分別可看到,幀率明顯上升,一幀圖像的繪制時間明顯下降,意味著動畫流暢性大幅提高,優(yōu)化目的已達(dá)到。再看細(xì)節(jié),我們發(fā)現(xiàn)繪制一幀動畫的事件組中,app.update 函數(shù)里沒有了 Recalculate style 和 Layout 事件,整個函數(shù)執(zhí)行時間因此顯著下降,證明我們的優(yōu)化方案起了作用。

本次關(guān)于性能工具的討論,我們從影響頁面性能的因素談起,隨之引出了 Performance 工具擅長的維度 —— 前端資源渲染。接著,我們了解了 Performance 工具 4 個主要面板:控制、預(yù)覽、線程、詳情,還有幾個實用的圖表:幀率條形圖、CPU 面積圖、主線程火焰圖、幀線程時序圖、事件耗時餅狀圖。然后運(yùn)用它們定位了一個性能問題,并著手解決了該問題。

上述就是小編為大家分享的Chrome DevTools中如何啟動Performance了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


新聞標(biāo)題:ChromeDevTools中如何啟動Performance
網(wǎng)頁路徑:http://weahome.cn/article/peoshs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部