摘要:分析每一秒的帧是用来分析动画的一个主要性能指标。轴代表了调用栈。在事件长条的右上角出,如果出现了红色小三角,说明这个事件是存在问题的,需要特别注意。双击这个带有红色小三角的的事件。
运行时性能表现(runtime performance)指的是当你的页面在浏览器运行时的性能表现,而不是在下载页面的时候的表现。这篇指南将会告诉你怎么用Chrome DevTools Performance功能去分析运行时性能表现。在RAIL性能评估模型下,你可以在这篇指南中可以学到怎么去用这个performance功能去分析Response, Animation, 以及 Idle 这三个性能指标。
让我们开始吧在这篇指南中,我们会用Performance工具去分析一个现有的在线DEMO,然后教会你怎么去分析,从而找到性能瓶颈。
打开Chrome的匿名模式。匿名模式可以保证Chrome在一个相对干净的环境下运行。比如说,你安装了许多chrome插件,这些插件可能会影响我们分析性能表现。
在匿名模式下打开右边这个链接,DEMO,这个网页就是我们要用来分析的DEMO。这个页面里都是很多上下移动的蓝色小方块。
按下Command+Opiton+I(Mac)或者Control+shift+I (Windows, Linux) 来打开Devtools
模拟移动设备的CPU移动设备的CPU一般比台式机和笔记本弱很多。当你想分析页面的时候,可以用CPU控制器(CPU Throttling)来模拟移动端设备CPU。
在DevTools中,点击 Performance 的 tab。
确保 Screenshots checkbox 被选中
点击 Capture Settings(⚙️)按钮,DevTools会展示很多设置,来模拟各种状况
对于模拟CPU,选择2x slowdown,于是Devtools就开始模拟两倍低速CPU
设置DEMO为了使得这个DEMO有相对统一的运行表现(不同的读者,机器的性能千差万别)。这个DEMO提供了自定义功能,用来确保这个DEMO的统一表现。
一直点击 Add 10 这个按钮直到你能很明显看到蓝色小方块移动变慢,在性能比较好的机器上,大概要点击20次左右。
点击 Optimize按钮,你会发现蓝色小方块会变的很快而且动画变得平滑。
点击 un-optimize 按钮,蓝色小方块又会变成之前的模样。
记录运行时性能表现在之前的DEMO中,当你运行优化模式的时候,蓝色小方块移动地非常快。为什么呢?明明两个模式都是移动了同样数量的小方块而且移动的时间也一样。那么现在我们在Performance界面下录制下发生的一切,并且学习如何分析这个记录,从而找到非优化模式下的性能瓶颈。
在DevTools中,点击 Record 。这时候Devtools就开始录制各种性能指标
等待几分钟
点击Stop按钮,Devtools停止录制,处理数据,然后显示性能报告
wow,看起来有非常多的数据,别害怕,我们一个一个来介绍
分析报告一旦你得到了页面的性能表现报告,那么就可以用它来分析页面的性能,从而找到性能瓶颈。
分析每一秒的帧FPS(frames per second)是用来分析动画的一个主要性能指标。能保持在60的FPS的话,那么用户体验就是不错的。
观察FPS图表,如果你发现了一个红色的长条,那么就说明这些帧存在严重问题,有可能导致非常差的用户体验。一般来说,绿色的长条越高,说明FPS越高,用户体验越好。
就在FPS图表下方,你会看到CPU图表。在CPU图表中的各种颜色与Summary面板里的颜色是相互对应的,Summary面板就在Performance面板的下方。CPU图表中的各种颜色代表着在这个时间段内,CPU在各种处理上所花费的时间。如果你看到了某个处理占用了大量的时间,那么这可能就是一个可以找到性能瓶颈的线索。
把鼠标移动到FPS,CPU或者NET图表之上,DevToos就会展示这个时间点界面的截图。左右移动鼠标,可以重发当时的屏幕录像。这被称为scrubbing, 他可以用来分析动画的各个细节。
在Frames图表中,把鼠标移动到绿色条状图上,Devtools会展示这个帧的FPS。每个帧可能都在60以下,都没有达到60的标准。
当然这个对于DEMO,可以相当容易观察到性能的问题。但是在现实使用场景下,就不是那么容易观察到了。所以要把常常使用这些工具来分析页面。
小功能:显示实时FPS面板
另外一个好用的小工具就是实时FPS面板,它可以实时展示页面的FPS指标
按下 Command+Shift+P(Mac)或者 Control+Shift+P(Windows, Linux) 打开命令菜单
输入Rendering,点选Show Rendering
在Rendering面板里,激活FPS Meter。FPS实时面板就出现在页面的右上方。
关闭FPS Meter只要按下Escape就可以了。这篇指南里暂时用不上这个功能。
定位瓶颈现在已经确定到这个页面的动画性能表现不太好,那么下一步就是找到为什么
注意Summary面板,你会发现CPU花费了大量的时间在rendering上。因为提高性能就是一门做减法的艺术,你的目标就是减少rendering的时间
展开Main图表,Devtools展示了主线程运行状况。X轴代表着时间。每个长条代表着一个event。长条越长就代表这个event花费的时间越长。Y轴代表了调用栈(call stack)。在栈里,上面的event调用了下面的event。
在性能报告中,有很多的数据。可以通过双击,拖动等等动作来放大缩小报告范围,从各种时间段来观察分析报告。
在事件长条的右上角出,如果出现了红色小三角,说明这个事件是存在问题的,需要特别注意。
双击这个带有红色小三角的的事件。在Summary面板会看到详细信息。注意reveal这个链接,双击它会让高亮触发这个事件的event。如果点击了app.js:94这个链接,就会跳转到对应的代码处。
在app.update这个事件的长条下方,有很多被触发的紫色长条。如果放大这些事件长条,你会看到它们每个都带有红色小三角。点击其中一个紫色事件长条,Devtools在Summary面板里展示了更多关于这个事件的信息。确实,这里有很多reflow的警告。
在summary面板里点击app.js:70链接,Devtools会跳转到需要优化的代码处
OK!Devtools里面还有很多很多指标需要你去探索,但是,对于怎么用Devtools去分析网页的运行时性能表现,你现在已经有了一个基本的概念。
PS:笔者最近开源一款由IBM主导开发设计的叫做Carvue.js的组件库,欢迎有兴趣的朋友一起开发。Carvue.js
译者博客
原文链接
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/88986.html
摘要:因此,如果可能,最好利用好毫秒响应预先计算开销大的工作,这样网站就更有可能实现的性能。空闲主线程工作分成不大于毫秒的块。点击按钮见图示,会在页面运行时捕获性能指标。 前言 经常能在博客或者论坛上看到很多有关前端性能优化的文章,但是却很少看到如何分析一个网页的性能的文章。到底什么样的指标(或者说是标准)代表这个网页性能好或者不好,通过什么方式来得到这些指标呢?因此,本文来讲述下如何分析一...
摘要:当一个按钮没有名字时,屏幕阅读器会宣布按钮。虽然每个元素的目的对于有视觉的用户来说可能是显而易见的,但对于依靠屏幕阅读器的用户来说并非如此。屏幕阅读器使视觉障碍的用户能够通过将文本内容转换为可以使用的表格如合成语音或盲文来使用您的网站。 Lighthouse是一个Google开源的自动化工具,主要用于改进网络应用(移动端)的质量。目前测试项包括页面性能、PWA、可访问性(无障碍)、最佳...
摘要:原文地址开始在本教程中,你将学会如何使用性能分析工具分析页面上的性能瓶颈。其中包含了捕获性能指标相关的设置。参考分析优化版的性能使用刚刚学习的工作流和工具,单击演示中的优化以启用优化的代码,进行另一次性能记录,然后分析结果。 原文地址:https://developers.google.com... 开始 在本教程中,你将学会如何使用性能分析工具分析页面上的性能瓶颈。 在隐身模式下打...
摘要:前端日报精选设计模式掘金优化向单页应用多路由预渲染指南掘金缓存机制一二三知乎专栏函数式编程在中的应用的学习笔记的学习笔记教程中文可持久化数据结构以及结构分享掘金第期如何准备一次技术面试附一套前端面试题翻译一些新姿势个人文章 2017-10-13 前端日报 精选 JavaScript设计模式 - 掘金优化向:单页应用多路由预渲染指南 - 掘金HTTP 缓存机制一二三 - 知乎专栏函数式编...
阅读 2087·2023-04-26 02:19
阅读 1813·2021-11-19 09:40
阅读 1648·2021-09-29 09:35
阅读 3470·2021-09-29 09:34
阅读 4200·2021-09-07 10:16
阅读 5439·2021-08-11 11:14
阅读 3519·2019-08-30 15:54
阅读 1565·2019-08-30 15:53