译文:前端性能的重要性 The Importance of Frontend Performance

欢迎访问我的主页,最新的文章我会首先发布在个人主页上:

http://blog.guaidm.com/shocky/

原书下载地址http://pan.baidu.com/s/1pJocRwB

在我的web开发生涯里,大部分时候我都是作为一个后台工程师。这样一来,我投入了非常多的精力去研究、练习如何通过后台优化来提升项目产品的性能,诸如编译器选项,数据库索引,内存管理等。很多书都花大量篇幅来讲述如何在这些方面提高性能,很多人也进而在这方面的优化花了大量时间。说实话,很多WEB网页,真正花费在web服务器到终端用户的时间其实往往不超过整个响应时间的一两成。如果你真的想极大幅度地减少web页面的响应时间,你应该把注意力放在真正影响终端用户体验的另外八九成的内容上。那这80%-90%的时间到底花费在哪了?怎样才能去减少?基于现如今WEB应用的基本原理,本书的以下章节便将来提供14条加速优化法则。

Tracking Web Page Performance

追踪网页性能

为了能够找到性能的提升点,我们必须知道用户的时间花在哪了。图表A-1展示了当用户用IE浏览器访问雅虎首页(http://www.yahoo.com)时的HTTP传输情况。每个横条是一个html请求。第一个名为html的横条是表示初始化HTML文档,浏览器解析HTML文本并开始下载其中的文档元素。在这个例子中,由于浏览器的缓存为空,所以所有的元素都需要进行下载。下载HTML文档仅仅耗费了全响应响应时间中的5%,所以另外95%的用户等待时间都用在了下载文档节点的具体元素内容上。当然,还有很小的一部分时间花在了等待解析HTML、脚本和CSS上,也就是图中两个下载条之中的空白区间。

图标A-2展示了使用IE浏览器第二次访问同一个URL地址时候的情况。HTML文档初始化依旧只占用了12%的总响应响应时间,而且绝大部分元素内容不需要再下载了,因为他们已经在浏览器的缓存里。

不过在第二次访问时,有5个元素还是被请求进行下载了:

一个重定向:

这个重定向的内容其实之前就下载过,但是浏览器还是又请求了一次,这回HTTP响应结果是302("Found" 或 "move temporarily") ,并且在返回的报头中并没有任何缓存信息,所以浏览器也没办法缓存本次响应结果。关于这个我将在章节B中对HTTP进行讨论。

三张未进行缓存的图片

接下来之所以三个图片被请求下载了是由于之前第一次访问时没有被下载缓存过,这三张图是新闻图片和广告图片,所以会被频繁的更换。

一张已经被缓存的图片

最后一个HTTP请求是一个条件GET请求。这个图片之前已经被缓存过了,但是由于HTTP的响应报头中的参数设置,浏览器必须在确保图片是最新版本的图片后才能给到用户。关于条件GET请求也会在章节B中进行讨论。

Where Does the Time Go?

时间都去哪了?

这么一来,我们发现:至少80%的响应时间是花在了下载页面元素内容上。当我们去深度挖掘这些图表的细节时,我们将会逐渐看到HTTP与浏览器之间及其复杂的交互过程。之前,我已经提到过HTTP的状态码和报头是如何影响浏览器的缓存操作的。除此之外,我们还能注意到以下几点:

1. 在使用了缓存的情况下(图表A-2),并不会有很多下载请求。相反,你会看到在HTML文档初始化解析完成后,紧接着出现一段没有任何下载记录的空白区域。这一段时间就是用来解析HTML文档,JS和CSS,同时也包括了从缓存中取出已有的元素内容。

2.时刻变化的并行HTTP请求数。图表A-2最多时候出现了3个并行的HTTP请求,然而在图表A-1中却有了多达6、7个HTTP请求同时出现。这种现象缘于不同域名的数量的影响,并且无论这个使用的协议HTTP/1.0还是HTTP/1.1
。 关于这个问题我们将在章节6“并行下载”中进行深入探讨。

3. 并行请求并不会发生在脚本被请求时,这是因为在绝大多数时候,浏览器会对除开下载脚本之外的请求进行阻塞。章节6中对此的原因进行了解释,并介绍了如何利用这种特点来加快页面加载速度。

精确找出时间到底花在哪了,这很难。但是要找出哪里没花时间,却很容易——下载HTML文档不费时,与之相关的任何的后台处理也不费时。既然这些不费时,那么我们便可以意识到,优化前端中那些费时的东西,是何等重要了。

The Performance Golden Rule

性能优化黄金条例

之前我们提到了只有10-20%的响应时间被花在了下载HTML文档上,而这种现象并不仅仅只发生在雅虎网站的首页。之前的这些数据特点能够非常好的适用于雅虎的几乎所有功能(除了雅虎的搜索功能,因为那个搜索页的元素实在太少了)。并且,这些统计数据同样适用于绝大部分网站。表格A-1展示了http://www.alexa.com选出的美国十大网站。当然有点小改动:除了AOL以外其他都是美国十大网站,其中Craigslist.org位列其中,但是该网站几乎没有图片,脚本和CSS,所以实在是没办法成为一个好的例子。所以我换做把AOL选入进来了。

同样的,几乎所有的网站都是在只将低于20%的响应时间用在下载HTML文档上,其中唯一的一个列外是在有缓存环境下的Google。这是因为http://www.google.com总共只有6个文档元素,除了一个元素以外,其他的所有元素都被设定为浏览器缓存处理。在之后的访问中,由于这些元素都已经被缓存了,就只剩下HTML文档请求和一个image
beacon。

在所有的性能优化中,最关键的是通过刻划界定当下的性能表现,来指出哪里才是真正能够大幅度提升行性能的要害之处。很明显,前端才是我们真正要关注的性能优化点。

首先,优化前端对总体性能的提升蕴藏着巨大的潜力。我们把后台系统处理的花费时间减半,那终端用户的响应时间无非就是缩短5-10%;相反,如果我们在前端上将时间减半,将可以缩短总响应时间的40-50%

其次,前端性能优化通常花费的时间更少,所需的资源也更少。要缩短后台的等待时间,我们往往会不可避免地要做各种的事情,比如重新设计架构与代码,找到并优化有问题的代码分支,添加或修改硬件设备,数据库分布式搭建等等。这些事往往需要花费几周乃至几个月时间。而我们之后一些章节要提到的前端性能优化措施,将都是更利于实际操作的最佳实践方案,诸如修改WEB服务器配置(章节3、4);变更脚本和CSS在web页面中的位置(章节5、6);合并图片、脚本和CSS(章节1)。而这些工作仅仅花费几个小时或者几天——这远远低于后台优化所需的时间。

再有,前端优化的实际价值已经得到印证。在雅虎,超过50个团队通过使用这些最佳实践方案,成功降低了终端用户的响应等待时间,缩减比例很多达到了25%甚至更多。当然,在很多时候,我们必须不拘泥于这些法则,根据网站的具体情况进行更具体的分析与优化,但是一般来说,通过这些最佳实践,提升25%的性能甚至更高,这都是完全有可能的。

在每一次开始进行行性能优化的时候,我都会画一个像类似A-1的图表,然后注明上性能优化的黄金法则:

     10-20%的时间其实使用来下载HTML文档,其他的80-90%时间是在下载页面元素。

本书的其他部分将会精确仔细的介绍这些如何降低这80-90%的耗费时间。为了说明清楚这些,我将会囊括很多方面的技术:HTTP请求头、JavaScript、CSS、Apache
等等。

考虑到HTTP的基础概念是理解本书的关键所在,我将这一块单独提升到了章节B来进行讲述。

在章节B后便是提升性能的14条法则,每一条法则一个章节。这些法则按照我们通常理解上的优先顺序来进行排序,当然,一个法则是否能够很好的适用于你特定的网站,这个要是具体情况而定。举例来说,法则2更适应于商业网站而并非适用于个人网站。如果你采用了所有的适合你的网站的优化手段,你将可以让你的页面访问速度提升25-50%,同时大大改善用户体验性。本书的最后章节展示了如何从性能角度来分析美国的十大网站。

时间: 2024-08-27 04:50:25

译文:前端性能的重要性 The Importance of Frontend Performance的相关文章

论前端设计中性能的重要性

前端性能的重要性 在我的web开发生涯里,大部分时候我都是作为一个后台工程师.这样一来,我投入了非常多的精力去研究.练习如何通过后台优化来提升项目产品的性能,诸如编译器选项,数据库索引,内存管理等.很多书都花大量篇幅来讲述如何在这些方面提高性能,很多人也进而在这方面的优化花了大量时间.说实话,很多WEB网页,真正花费在web服务器到终端用户的时间其实往往不超过整个响应时间的一两成.如果你真的想极大幅度地减少web页面的响应时间,你应该把注意力放在真正影响终端用户体验的另外八九成的内容上.那这80

Web性能API——帮你分析Web前端性能

前端性能统计必备api,有不知道的吗? 正文从这开始- 开发一个现代化的互联网网站是一项复杂的任务,需要各种职能的密切合作以应对用户日新月异的需求.其中,网页的性能直接决定了用户的体验,而随着新型客户端浏览设备的出现与网站功能的日益复杂化,对于性能的专注也达到了前所未有的高度. 传统的网站性能监测通常有以下几种方式: 借助传统的开发者工具查看网络请求,例如浏览器的F12工具.Fiddler.Charles等等.基本方式是通过追踪HTTP请求与响应的时间,以图形的方式列出所有资源的下载情况.这种方

合理提升WEB前端性能

前端的优化包括四个部分:HTML结构优化.CSS样式优化.JS行为优化.服务器的优化.合理的前端优化不仅能够提升网站加载速度,而且能够更好的提升用户体验和团队开发效率.所以前端性能优化的重要性是不言而喻的. HTML部分 语义化HTML:好处在于可以使代码简洁清晰,支持不同设备,利于搜索引擎,便于团队开发: 减少DOM节点:加速页面渲染: 给图片加上正确的宽高值:这可以减少页面重绘,同时防止图片缩放: 防止src属性和link的href属性为空:当值为空时,浏览器很可能会把当前页面当成其属性值加

web前端性能优化

前言:  在同样的网络环境下,两个同样能满足你的需求的网站,一个“Duang”的一下就加载出来了,一个纠结了半天才出来,你会选择哪个?研究表明:用户最满意的打开网页时间是2-5秒,如果等待超过10秒,99%的用户会关闭这个网页.也许这样讲,各位还不会有太多感触,接下来我列举一组数据:Google网站访问速度每慢400ms就导致用户搜索请 求下降0.59%;Amazon每增加100ms网站延迟将导致收入下降1%;雅虎如果有400ms延迟会导致流量下降5-9%.网站的加载速度严重影响了用户体验,也决

性能测试(六)前端性能优化方法

日常工作和生活中,我们经常利用浏览器去打开一些URL来获取我们所需的资源,那么作为一个开发者或者性能测试工程师,如何去测试并提升优化前端的性能呢? 一.浏览器打开URL和方式和过程 不同浏览器工作方式不完全一样,大体来讲,浏览器的核心是浏览器引擎:不同浏览器对W3C的规范支持不尽相同,在具体功能的实现上也不完全一致. 1.连接到URL所在的服务器 用户在浏览器地址栏输入URL,打开URL时,浏览器首先寻找该URL所在的服务器.通过向DNS服务器查询,获取该URL所在网站的IP地址,然后浏览器向该

CSS3与页面布局学习总结(八)——浏览器兼容与前端性能优化

目录 一.浏览器兼容 1.1.概要 1.2.浏览器内核 1.3.浏览器市场份额(Browser Market Share) 1.4.兼容的一般标准 1.5.CSS Reset 1.6.CSS Hack 1.6.1.条件注释法 1.6.2.样式内属性标记法 1.6.3.选择器前缀法 1.7.文档模式 (X-UA-Compatible) 1.8.javascript兼容 二.前端性能优化 2.1.概要 2.2.减少HTTP请求数量 2.2.1.图片地图 2.2.2.精灵图片(Sprite) 2.2.

WebPack实例与前端性能优化

[前端构建]WebPack实例与前端性能优化 计划把微信的文章也搬一份上来. 这篇主要介绍一下我在玩Webpack过程中的心得.通过实例介绍WebPack的安装,插件使用及加载策略.感受构建工具给前端优化工作带来的便利. 壹 | Fisrt 曾几何时,我们是如上图的方式引入JS资源的,相信现在很少遇见了.近年来Web前端开发领域朝着规范开发的方向演进.体现在以下两点: MVC研发构架.多多益处(逻辑清晰,程序注重数据与表现分离,可读性强,利于规避和排查问题...) 构建工具层出不穷.多多益处(提

新产品为了效果,做的比较炫,用了很多的图片和JS,所以前端的性能是很大的问题,分篇记录前端性能优化的一些小经验。

第一篇:HTTP服务器 因tomcat处理静态资源的速度比较慢,所以首先想到的就是把所有静态资源(JS,CSS,image,swf) 提到单独的服务器,用更加快速的HTTP服务器,这里选择了nginx了,nginx相比apache,更加轻量级, 配置更加简单,而且nginx不仅仅是高性能的HTTP服务器,还是高性能的反向代理服务器. 目前很多大型网站都使用了nginx,新浪.网易.QQ等都使用了nginx,说明nginx的稳定性和性能还是非常不错的. 1. nginx 安装(linux) htt

前端性能优化归纳总结

关于前端性能优化的总结,随处都可以看到这方面的文章,而优化方法,也无外乎那些"固定"方面,当然,有些方面已经过时,所以,在这里,我自己也总结一遍吧,加深理解,也希望是一种不同的总结形式. -----------------------正文总这里开始------------------------------------ 一.什么是前端性能优化(what)? 从用户访问资源到资源完整的展现在用户面前的过程中,通过技术手段和优化策略,缩短每个步骤的处理时间从而提升整个资源的访问和呈现速度.