注: 这一篇主要讲解面板Network,参考了Google的相关文档,主要用于公司内部技术分享。chrome
Chrome开发者工具面板
面板上包含了Elements面板、Console面板、Sources面板、Network面板、
Timeline面板、Profiles面板、Application面板、Security面板、Audits面板这些功能面板。
这些按钮的功能点以下:浏览器
- Elements:查找网页源代码HTML中的任一元素,手动修改任一元素的属性和样式且能实时在浏览器里面获得反馈。
- Console:记录开发者开发过程当中的日志信息,且能够做为与JS进行交互的命令行Shell。
- Sources:断点调试JS。
- Network:从发起网页页面请求Request后分析HTTP请求后获得的各个请求资源信息(包括状态、资源类型、大小、所用时间等),能够根据这个进行网络性能优化。
- Timeline:记录并分析在网站的生命周期内所发生的各种事件,以此能够提升网页的运行时间的性能。
- Profiles:若是你须要Timeline所能提供的更多信息时,能够尝试一下Profiles,好比记录JS CPU执行时间细节、显示JS对象和相关的DOM节点的内存消耗、记录内存的分配细节。
- Application:记录网站加载的全部资源信息,包括存储数据(Local Storage、Session Storage、IndexedDB、Web SQL、Cookies)、缓存数据、字体、图片、脚本、样式表等。
- Security:判断当前网页是否安全。
- Audits:对当前网页进行网络利用状况、网页性能方面的诊断,并给出一些优化建议。好比列出全部没有用到的CSS文件等。
Network面板
概述
Network
面板能够记录页面上的网络请求的详情信息,从发起网页页面请求Request后分析HTTP请求后获得的各个请求资源信息(包括状态、资源类型、大小、所用时间、Request和Response等),能够根据这个进行网络性能优化。缓存
我把Google官方网站上介绍Network面板的图贴到这里,该面板主要包括5大块窗格(Pane):安全
- Controls 控制Network的外观和功能。
- Filters 控制Requests Table具体显示哪些内容。
- Overview 显示获取到资源的时间轴信息。
- Requests Table 按资源获取的先后顺序显示全部获取到的资源信息,点击资源名能够查看该资源的详细信息。
- Summary 显示总的请求数、数据传输量、加载时间信息。
其中 Requests Table 显示以下信息列:性能优化
- Name 资源名称,点击名称能够查看资源的详情状况,包括
Headers
、Preview
、Response
、Cookies
、Timing
。 - Status HTTP状态码。
- Type 请求的资源MIME类型。
- Initiator 标记请求是由哪一个对象或进程发起的(请求源)。
- Parser: 请求由Chrome的HTML解析器时发起的。
- Redirect:请求是由HTTP页面重定向发起的。
- Script:请求是由Script脚本发起的。
- Other:请求是由其余进程发起的,好比用户点击一个连接跳转到另外一个页面或者在地址栏输入URL地址。
- Size 从服务器下载的文件和请求的资源大小。若是是从缓存中取得的资源则该列会显示(from cache)
- Time 请求或下载的时间,从发起Request到获取到Response所用的总时间。
- Timeline 显示全部网络请求的可视化瀑布流(时间状态轴),点击时间轴,能够查看该请求的详细信息,点击列头则能够根据指定的字段能够排序。
捕获屏幕
Controls
窗格包括的功能有网络日志录制、日志清理、捕获屏幕、过滤器,视图切换、保留日志开关、Cache开关、网络链接开关、网速阀值。服务器
以捕获屏幕为例,点击摄像机按钮(捕获屏幕),从新加载页面便可捕获屏幕。markdown
双击其中的截屏能够放大显示,在放大的图下方能够点击跳转到上一帧或者下一帧。网络
单击则能够查看该帧被捕获时的网络请求信息,而且在Overview上会有一条黄色竖线以标记该帧被捕获的具体时间点。并发
查看DOMContentLoaded和load事件信息
DOMContentLoaded
和load
这两个事件会高亮显示。框架
DOMContentLoaded事件会在页面上DOM彻底加载并解析完毕以后触发,不会等待CSS、图片、子框架加载完成。
load事件会在页面上全部DOM、CSS、JS、图片彻底加载完毕以后触发。
DOMContentLoaded
事件在Overview上用一条蓝色竖线标记,而且在Summary以蓝色文字显示确切的时间。
load
事件一样会在Overview和Requests Table上用一条红色竖线标记,在Summary也会以红色文字显示确切的时间。
查看具体资源的详情
经过点击某个资源的Name能够查看该资源的详细信息,根据选择的资源类型显示的信息也不太同样,可能包括以下Tab信息:
- Headers 该资源的HTTP头信息。
- Preview 根据你所选择的资源类型(JSON、图片、文本)显示相应的预览。
- Response 显示HTTP的Response信息。
- Cookies 显示资源HTTP的Request和Response过程当中的Cookies信息。
- Timing 显示资源在整个请求生命周期过程当中各部分花费的时间。
针对上面4个Tab进行详细讲解一下各个功能:
① 查看资源HTTP头信息
在Headers标签里面能够看到HTTP Request URL
、HTTP Method
、Status Code
、Remote Address
等基本信息和详细的Response Headers
、Request Headers以及Query String Parameters或者Form Data等信息。
② 查看资源预览信息
在Preview标签里面可根据选择的资源类型(JSON、图片、文本、JS、CSS)显示相应的预览信息。下图显示的是当选择的资源是JSON格式时的预览信息。
③ 查看资源HTTP的Response信息
在Response标签里面可根据选择的资源类型(JSON、图片、文本、JS、CSS)显示相应资源的Response响应内容。下图显示的是当选择的资源是CSS格式时的响应内容。
④ 查看资源Cookies信息
若是选择的资源在Request和Response过程当中存在Cookies信息,则Cookies标签会自动显示出来,在里面能够查看全部的Cookies信息。
⑤ 分析资源在请求的生命周期内各部分时间花费信息
在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请求时间和得到响应消息第一个字节的时间。
- Content Download 获取Response响应数据的时间花费。
TTFB这个部分的时间花费若是超过200ms,则应该考虑对网络进行性能优化了,能够参见网络性能优化方案及里面的相关参考文档。
查看资源的发起者(请求源)和依赖项
经过按住Shift
而且把光标移到资源名称上,能够查看该资源是由哪一个对象或进程发起的(请求源)和对该资源的请求过程当中引起了哪些资源(依赖资源)。
在该资源的上方第一个标记为绿色的资源就是该资源的发起者(请求源),有可能会有第二个标记为绿色的资源是该资源的发起者的发起者,以此类推。
在该资源的下方标记为红色的资源是该资源的依赖资源。