Google開發者F12工具面板-network詳解


1 開發者工具面板
    面板上包含了Elements面板、Console面板、Sources面板、Network面板、Performance面板、Memory面板、Application面板、Security面板、Audits面板。

 

這些按鈕的功能點如下:

·        Elements:查找網頁源代碼HTML中的任一元素,手動修改任一元素的屬性和樣式且能實時在瀏覽器里面得到反饋。

·        Console:記錄開發者開發過程中的日志信息,且可以作為與JS進行交互的命令行Shell。

·        Sources:斷點調試JS。

·        Network:從發起網頁頁面請求Request后分析HTTP請求后得到的各個請求資源信息(包括狀態、資源類型、大小、所用時間等),可以根據這個進行網絡性能優化。

·        Application:記錄網站加載的所有資源信息,包括存儲數據(Local Storage、Session Storage、IndexedDB、Web SQL、Cookies)、緩存數據、字體、圖片、腳本、樣式表等。

·        Security:判斷當前網頁是否安全。

·        Audits:對當前網頁進行網絡利用情況、網頁性能方面的診斷,並給出一些優化建議。比如列出所有沒有用到的CSS文件等。

2 Network面板
2.1 面板功能分布
    Network面板可以記錄頁面上的網絡請求的詳情信息,從發起網頁頁面請求Request后分析HTTP請求后得到的各個請求資源信息(包括狀態、資源類型、大小、所用時間、Request和Response等),可以根據這個進行網絡性能優化。該面板主要包括5大塊窗格:

 

Controls 控制Network的外觀和功能。
Filters 控制Requests Table具體顯示哪些內容。
Overview 顯示獲取到資源的時間軸信息。
Requests Table 按資源獲取的前后順序顯示所有獲取到的資源信息,點擊資源名可以查看該資源的詳細信息。
Summary 顯示總的請求數、數據傳輸量、加載時間信息。
2.2 請求資源面板
Name 資源名稱,點擊名稱可以查看資源的詳情情況,包括Headers、Preview、Response、Cookies、Timing。
Status HTTP狀態碼。
Type 請求的資源MIME類型。
Initiator 標記請求是由哪個對象或進程發起的(請求源)。
Size 從服務器下載的文件和請求的資源大小。如果是從緩存中取得的資源則該列會顯示(from cache)
Time 請求或下載的時間,從發起Request到獲取到Response所用的總時間。
Watefall顯示所有網絡請求的可視化瀑布流(時間狀態軸),點擊時間軸,可以查看該請求的詳細信息,點擊列頭則可以根據指定的字段可以排序。
2.3 捕獲屏幕
    Controls窗格包括的功能有網絡日志錄制、日志清理、捕獲屏幕、過濾器,視圖切換、保留日志開關、Cache開關、網絡連接開關、網速閥值。

    以捕獲屏幕為例,點擊攝像機按鈕(捕獲屏幕),重新加載頁面即可捕獲屏幕。

    雙擊其中的截屏可以放大顯示,在放大的圖下方可以點擊跳轉到上一幀或者下一幀。單擊則可以查看該幀被捕獲時的網絡請求信息,並且在Overview上會有一條黃色豎線以標記該幀被捕獲的具體時間點。

 

2.4 查看DOMContentLoaded和load事件信息
DOMContentLoaded和Load這兩個事件會高亮顯示。

DOMContentLoaded事件會在頁面上DOM完全加載並解析完畢之后觸發,不會等待CSS、圖片、子框架加載完成。

load事件會在頁面上所有DOM、CSS、JS、圖片完全加載完畢之后觸發。

DOMContentLoaded事件在Overview上用一條藍色豎線標記,並且在Summary以藍色文字顯示確切的時間。

Load事件同樣會在Overview和RequestsTable上用一條紅色豎線標記,在Summary也會以紅色文字顯示確切的時間。

 

2.5 查看具體資源的詳情
通過點擊某個資源的Name可以查看該資源的詳細信息,根據選擇的資源類型顯示的信息也不太一樣,可能包括如下Tab信息:

Headers 該資源的HTTP頭信息。
Preview 根據你所選擇的資源類型(JSON、圖片、文本)顯示相應的預覽。
Response 顯示HTTP的Response信息。
Cookies 顯示資源HTTP的Request和Response過程中的Cookies信息。
Timing 顯示資源在整個請求生命周期過程中各部分花費的時間。
針對上面4個Tab進行詳細講解一下各個功能:

2.5.1 查看資源HTTP頭信息
    在Headers標簽里面可以看到HTTP   Request、URL、HTTP Method、Status Code、Remote Address 等基本信息和詳細的Response Headers、RequestHeaders以及Query String Parameters或者FormData等信息。

 

2.5.2 查看資源預覽信息
在Preview標簽里面可根據選擇的資源類型(JSON、圖片、文本、JS、CSS)顯示相應的預覽信息。下圖顯示的是當選擇的資源是JSON格式時的預覽信息。

 

2.5.3 查看資源HTTP的Response信息
在Response標簽里面可根據選擇的資源類型(JSON、圖片、文本、JS、CSS)顯示相應資源的Response響應內容。下圖顯示的是當選擇的資源是CSS格式時的響應內容。

 

2.5.4 查看資源Cookies信息
如果選擇的資源在Request和Response過程中存在Cookies信息,則Cookies標簽會自動顯示出來,在里面可以查看所有的Cookies信息。

 

2.5.5 分析資源在請求的生命周期內各部分時間花費信息
在Timing標簽中可以顯示資源在整個請求生命周期過程中各部分時間花費信息,可能會涉及到如下過程的時間花費情況:

 

·        Queuing :排隊的時間花費。可能由於該請求被渲染引擎認為是優先級比較低的資源(圖片)、服務器不可用、超過瀏覽器的並發請求的最大連接數(Chrome的最大並發連接數為6).

·        Stalled :從HTTP連接建立到請求能夠被發出送出去(真正傳輸數據)之間的時間花費。包含用於處理代理的時間,如果有已經建立好的連接,這個時間還包括等待已建立連接被復用的時間。

·        Proxy Negotiation :與代理服務器連接的時間花費。

·        DNS Lookup :執行DNS查詢的時間。網頁上每一個新的域名都要經過一個DNS查詢。第二次訪問瀏覽器有緩存的話,則這個時間為0。

·        Initial Connection / Connecting :建立連接的時間花費,包含了TCP握手及重試時間。

·        SSL :完成SSL握手的時間花費。

·        Request sent :發起請求的時間。

·        Waiting (Time to first byte(TTFB)) :是最初的網絡請求被發起到從服務器接收到第一個字節這段時間,它包含了TCP連接時間,發送HTTP請求時間和獲得響應消息第一個字節的時間。TTFB這個部分的時間花費如果超過200ms,則應該考慮對網絡進行性能優化了。

·        Content Download: 獲取Response響應數據的時間花費。

2.6 查看資源的發起者(請求源)和依賴項
通過按住Shfit並且把光標移到資源名稱上,可以查看該資源是由哪個對象或進程發起的(請求源)和對該資源的請求過程中引發了哪些資源(依賴資源)。

在該資源的上方第一個標記為綠色的資源就是該資源的發起者(請求源),有可能會有第二個標記為綠色的資源是該資源的發起者的發起者,以此類推。

 

在該資源的下方標記為紅色的資源是該資源的依賴資源。

 

原文鏈接:https://blog.csdn.net/zengzhenzong/article/details/80446732


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM