不是全部人都可以使用高速 Internet 链接。即便每一个人都可以使用高速网络,也会由于各类各样的缘由使您的 Web 应用程序看起来运行缓慢。在这个宽带速度不断提升的时代,您应当关注一下页面加载时间。将珍贵的页面加载时间缩短几秒,将更加珍贵的请求和响应时间缩短几毫秒。您将为访问者创造一种更好的体验。javascript
阅读完本文以后,您将可以较好地了解网页加载时间优化的基本知识。您还可以使用工具和知识更好地识别和判断加载缓慢的页面部分和瓶颈。php
在理想状况下,您应该安装了 Mozilla Firefox。您还应该大致了解 Web 开发。本文涉及的主题并不复杂,可是若是您了解超文本标记语言(Hypertext Markup Language,HTML)、层叠样式表(Cascading Style Sheet,CSS)以及 ™ 编程语言等主题,那么在学习本文时将更加驾轻就熟。不须要使用集成开发环境(IDE),只需使用您喜好的编辑器。css
您必须在浏览器中启用了 JavaScript。另外,要学习与 Firebug 和 YSlow 相关的内容,您须要安装 Firefox Web 浏览器。html
许多人经过某种形式的宽带链接访问 Internet,这些形式多是 DSL、网线、光纤或其余方法。可是,没法使用这类技术的用户不得不使用拨号链接。您必定已经忘记拨号上网是什么感受了,但您能够试着回想一下网页逐行加载时的情形。java
幸运的是,这些可怜的人们如今已经可以得到一些帮助。您能够经过缩短加载页面的时间来改善他们的体验。可是,拨号链接并非下降加载和响应速度的唯一缘由。许多 Web 设计人员错误地认为高速 Internet 链接的到来会使网站性能优化变得没有必要。这种观点是不对的。例如,过去使用桌面软件执行的许多任务如今能够在线执行。在 Web 应用程序中得到像桌面软件那样的高速响应体验很是困难,所以性能优化很是重要。幸运的是,一些工具和最佳实践可用于缩短响应和加载时间,提供更加流畅的体验。ajax
对于全部与优化相关的任务,您必须使用工具来诊断瓶颈和识别问题。如今在 Web 开发中使用最普遍的两个工具是 Firebug 和 YSlow,它们都是开源、免费的 Firefox 插件。数据库
Firebug(参见 参考资料)是最流行的 Firefox 扩展之一,该应用程序可以使 Web 开发人员的工做更加轻松。它包含许多很是有用的功能,好比:编程
XmlHttpRequests
YSlow(参见 参考资料)分析网页,并根据 Yahoo! 起草的高性能网站规则(参见 参考),告诉您网页加载缓慢的缘由。YSlow 是一个与 Firebug 集成的 Firefox 插件,所以您须要首先安装 Firebug,而后才能安装和使用 YSlow。
两个 Firefox 扩展的安装过程都很是简单。要安装 Firebug,执行如下步骤:
您如今能够从 Tools 菜单访问 Firebug。能够在新窗口或现有窗口中打开 Firebug(参见 图 1)。
安装 Firebug 以后,接下来安装 YSlow。为此,执行如下步骤:
注意:与许多其余 Firefox 扩展不一样,YSlow 不会自动启动。必须首先激活它。
图 2 显示了 YSlow 性能分析的结果。
使人惊讶的是简单的设计规则一般会被忽视,最终产生未经优化的、下载缓慢的网页。牢记如下规则,页面的加载速度将会更快。
可扩展 HTML (XHTML) 具备许多优点,可是其缺点也很明显。XHTML 可能使您的页面更加符合标准,可是它大量使用标记(强制性的<start>
和 <end>
标记),这意味着浏览器要下载更多代码。因此,事情都有两面性,尝试在您的网页中使用较少的 XHTML 代码,以减少页面大小。
若是您确实不得不使用 XHTML,试着尽量对它进行优化。例如,删除空格并采用严格的 XHTML 编码实践,提升下载和解析速度。要严格执行 XHTML Strict 规则,向文档中添加如下 doctype
语句:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
XHTML 1.0 Strict 与 Strict HTML 4.01 是等效的,包含的属性和元素没有出如今 HTML 4.01 规范的反对内容中。记住,有两个标记可以在 XHTML Transitional 中使用,但不能在 XHTML Strict 中使用,例如:
<center>
<font>
<iframe>
<strike>
<u>
在博客(和新的站点)流行起来以前,让页面水平滚动甚至垂直滚动被认为是糟糕的实践。页面越小,越难以(但并非不可能)无缺地填充屏幕。如今,对于博客和内容驱动的网站,不时能够看到几百 Kb 大小的长页面。是的,您须要填充更多空间,可是这并不意味着您必须使用大的背景图像、大量表格或者许多内容来填充。坚持简约原则:少便是多。页面中充斥着各类类型的图像、视频、广告等,这大大违背实用性原则,所以,在增长页面的内容时请三思。
咱们不多会控制字体在不一样浏览器中的显示方式,与字体不一样的是,图像老是精确地按照其设计方式来显示。但这不能看成使用图像来表示文本的借口。
使用图像表示文本的最多见示例就是在导航栏中。美观的按钮更加具备吸引力,可是它们的加载速度很慢。此外,图像仍然不能由搜索引擎直接索引,所以,使用图像进行导航不利于搜索引擎优化(search engine optimization,SEO)。当无需图像就能够经过大量 CSS 技巧建立漂亮的按钮时,毫不使用图像来表示文本。
一种适用于 CSS 样式的特定导航类型就是选项卡式导航,如 图 3 所示。
除了体积较小以外,这种实现导航的方式也更加符合 Web 标准。
清单 1 和 清单 2 中的代码以纯 CSS/XHTML 的形式实现基于选项卡的导航功能。
#nav { float:left; width:100%; background:#E7E5E2; font-size:95%; line-height:normal; border-bottom:1px solid #54545C; } #nav ul { margin:0; padding:10px 10px 0 50px; list-style:none; } #nav li { display:inline; margin:0; padding:0; } #nav a { float:left; background:url("tableftK.gif") no-repeat left top; margin:0; padding:0 0 0 4px; text-decoration:none; } #nav a span { float:left; display:block; background:url("tabrightK.gif") no-repeat right top; padding:5px 15px 4px 6px; color:#FFF; } /* Commented Backslash Hack hides rule from IE5-Mac \*/ #nav a span {float:none;} /* End IE5-Mac hack */ #nav a:hover span { color:#FFF; background-position:100% -42px; } #nav a:hover { background-position:0% -42px; } #nav a:hover span { background-position:100% -42px; }
<div id="nav"> <ul> <li><a href="#" title="Link 1"><span>Link 1</span></a></li> <li><a href="#" title="Link 2"><span>Link 2</span></a></li> <li><a href="#" title="Link 3"><span>Link 3</span></a></li> <li><a href="#" title="Longer Link Text"><span>Longer Link Text</span></a></li> <li><a href="#" title="Link 5"><span>Link 5</span></a></li> </ul> </div>
cookie 多是很小的文件,可是浏览器仍然须要下载它们。较大的 cookie 所需的下载时间更长,进而增长了浏览器加载网页的时间。正由于如此,尽量缩小 cookie 来最小化对浏览器响应时间的影响很是重要。
此外,设置一个较早的 expire
日期或者根本不设置 expire
日期,会缩短响应时间。要在 PHP 语言中设置 cookie 的 expire
日期,使用如下代码:
<?php $expire = 2592000 + time(); // Add 30 day’s to the current time setcookie(userid, “123rrw3”, $expire); ?>
这段代码设置 cookie userid
,并将 expire
日期设置为自当前日期以后 30 天。
与 cookie 相似,JavaScript 文件的下载也须要时间,这不可避免地会下降整个页面的加载速度。所以,明智地使用 JavaScript(仅在真正必要时才使用)并优化脚本的大小和速度。
缩短 JavaScript 下载时间的另外一种方式是使用外部文件,而不是包含脚本内联。这种方法也适用于 CSS,由于浏览器会缓存外部化的文本,而(在 HTML 页面自身中)之内联方式编码的 CSS 或 JavaScript 每次都会随 HTML 一块儿加载。要经过在 HTML 中引用 CSS 和 JavaScript 代码来外部化它们,可使用具备如下形式的代码:
<link href="/stylesheets/myStyle.css" media="all" rel="Stylesheet" type="text/css" /> <script src="/javascripts/myJavascript.js" type="text/javascript"></script>
表格被用做网页的主要构建块,可是做为页面布局元素,使用表格如今被认为是糟糕的作法。有时候,您必须使用表格(而且它们被认为是显示表格数据的出色实践)。若是是这样,明确地指定表格单元格、行和列的宽度和高度,不然,浏览器必须执行许多操做来计算如何显示它们,这会下降页面加载速度:
<td width="50px" height="10px">...</td>
可能这是全部技巧中最显而易见的一个,可是它也是最容易忘记的一个技巧。我曾经提到过 “少便是多”:这不只是为了真正吸引更普遍的用户,还意味着须要下载和处理的东西更少。若是您真正须要在网页上放置许多内容,考虑将网页分为 2 个、3 个或更多的独立页面。
可使用许多方法来优化您的网页,包括压缩 JavaScript 文件,使用超文本传输协议(Hypertext Transfer Protocol,HTTP)压缩,以及设置图像大小。
JavaScript 文件可能很是大,这意味着在某些情形中,它们的下载时间可能比全部其余组件下载时间之和还长。解决此问题的一种方法是压缩 JavaScript 文件。您可使用 GNU zip (gzip) 来完成此任务,由于许多浏览器都支持这种压缩算法。
另外一种替代方法是缩小文件。这种方法删除代码中全部没必要要的字符,好比制表符(tab)、新行和空格。它删除代码中的注释和空白,进一步缩小文件大小。外部和内部样式表均可以缩小。两种最流行的缩小工具是 JSMin 和 YUI Compressor(参见 参考资料)。
可使用 HTTP 压缩来减小服务器与浏览器之间的通讯量。能够在 Apache 中配置 HTTP 压缩(.htaccess 文件),或者能够将其包含到页面中(对于 PHP,可使用一个 HTTP_ACCEPT_ENCODING
选项)。可是请注意:不是全部浏览器都支持压缩。即便是支持压缩的浏览器,压缩和解压缩都会加剧处理器的负载。要在 Apache 中启用地毯式(blanket)压缩(即压缩全部文本和 HTML),使用如下命令:
AddOutputFilterByType DEFLATE text/html text/plain text/xml
另外,考虑一下您想要压缩的内容。图像、音乐和视频在建立时已经进行了压缩,所以您能够将压缩对象限制为 HTML、CSS 和 JavaScript 文件。
另外一种减小压缩工做的技巧是使用小写形式的 <div>
元素和类名。因为大小写敏感性,而且使用的是无损压缩,<header>
与 <Header>
不一样,它们被压缩为两个不一样的标记。在下面的例子中,对于压缩程序来讲,Important
类与 important
类是不一样的,这意味着对于压缩程序,它们表示不一样的对象,所以被分别压缩为两段不一样的文本。
<div class="Important">read this!</div> <div class="important">This will cost you some valuable load time</div>
留意细节彷佛可有可无。可是当您优化文件时,全部细微的细节都应考虑在内。
与表格单元格、行和列同样,当您未明确设置图像大小时,浏览器须要执行计算来显示图像,这会下降处理速度。此外,在某些情形下,图像大小的计算结果可能不正确,所以图像会发生变形。
使用图像映射代替多个图像,这是另外一种缩短加载时间的方式,由于同时下载图像的各个独立部分可以加快整个页面的下载进度。或者,您可使用某种名为 CSS sprites 的工具(参见 参考资料)。CSS sprites 可帮助减小 HTTP 请求的数量。一个图像能够包含装饰或布置页面所需的全部图像元素。您使用 CSS 来选择(经过调用某些位置和维度)用于特定元素的映射。
我 在前面 提到过,移除彻底不须要的 JavaScript 代码可以加快加载和处理速度。可是若是代码已经很是精简而且必须在页面中包含 JavaScript 代码的话,该怎么办?
在这种情形下,一种提高页面下载速度的潜在方式是将脚本放在页面的底部,使页面加载更迅速。一般,浏览器只能(从同一个域)下载不超过两个并行对象,若是一个对象是一段 JavaScript 代码,那么在该脚本下载完以前,其余页面组件的下载将会暂停。若是将 JavaScript 代码放在页面底部,(在大多数状况下)它将在最后下载,这时全部其余组件都已下载完。
使用 Firebug 扩展跟踪加载缓慢的文件,我敢打赌您的 JavaScript 文件是下载最慢的文件。压缩 JavaScript 文件会有所帮助,可是仅仅这样可能还不够。您可使用如下代码片断延迟 JavaScript 的加载:
var delay = 5; setTimeout("heavy();", delay * 1000);
这段代码将对 heavy()
方法的调用延迟了 5 秒。您能够将这段代码与下面的技巧结合使用来延迟整个 JavaScript 文件的加载。
要按需加载 JavaScript,使用 import() 函数,如 清单 3 所示。
function $import(src){ var scriptElem = document.createElement('script'); scriptElem.setAttribute('src',src); scriptElem.setAttribute('type','text/javascript'); document.getElementsByTagName('head')[0].appendChild(scriptElem); } // import with a random query parameter to avoid caching function $importNoCache(src){ var ms = new Date().getTime().toString(); var seed = "?" + ms; $import(src + seed); }
也能够验证一个函数是否被加载,若是没有,加载 JavaScript 文件。为此,使用 清单 4 中的代码。
if (myfunction){ // The function has been loaded } else{ // Function has not been loaded yet, so load the javascript. $import('http://www.yourfastsite.com/myfile.js'); }
注意:可使用 defer
属性,但不是全部浏览器(包括 Firefox)都支持它。
若是通过适当优化和维护,CSS 文件不必定很大。例如,具备不少独立类的 CSS 文件会影响下载速度。与 JavaScript 文件同样,您须要优化 CSS 文件,使其包含所需的全部内容,同时保持合理的大小。另外,使用外部文件代替内联定义来适应浏览器的缓存机制。
内容分布网络(Content-distribution network,CDN)是另外一种缩短下载时间的好方法。当您将静态图像放在 Internet 上的许多服务器上时,用户可以从离他们最近的服务器下载这些图像。此外,大多数 CDN 都在快速服务器上运行,所以不管服务器的加载速度如何,其响应速度都比小型的超载服务器快。
CDN 的另外一个优点是它们是独立的域。由于您的浏览器将并发链接的数量限制到一个单一的域,所以不管什么时候加载一个页面,都很容易占满全部线程。所以,到其余资产的链接被延迟了。然而,您的浏览器可以打开新线程或到其余域的链接,这样,从另外一个域加载的任何资产均可以与其余全部资产同时加载。
使用 Google Gears(参见 参考资料)是避免用户反复下载同一内容的另外一种好方法。Gears 容许用户离线访问 Web 应用程序,可是也容许将页面元素持久化到用户的计算机上。所以,频繁加载但未进行更新的内容能够存储在 Gears 数据库中,该数据库是一个 SQLite3 关系数据库管理系统。对同一内容的全部 next
请求均可以从数据库(而不是服务器)直接加载。
安装 Gears 以后,获取 gears_init.js 文件,以便轻松访问 Gears 工厂和应用程序编程接口(API),将其保存为 gears_init.js,经过如下方式在您的代码中引用它:
<script type="text/javascript" src="gears_init.js"></script>
要肯定是否已安装 Gears,使用 清单 5 中的代码。
<script> if (!window.google || !google.gears) { location.href = "http://gears.google.com/?action=install&message=<welcome message>" + "&return=<return url>"; } </script>
若是未安装 Gears,代码将向您提供下载 Gears 的 URL。
当全部元素都经过验证而且 Gears 已安装以后,您能够测试 Gears 的极其有用的数据库功能,使用 清单 6 中的 JavaScript 代码。
<script type="text/javascript"> var db = google.gears.factory.create('beta.db'); db.open('database-test'); db.execute('create table if not exists Test' + ' (Phrase text, Timestamp int)'); db.execute('insert into Test values (?, ?)', ['Monkey!', new Date().getTime()]); var rs = db.execute('select * from Test order by Timestamp desc'); while (rs.isValidRow()) { alert(rs.field(0) + '@' + rs.field(1)); rs.next(); } rs.close(); </script>
这段代码在您的计算机或服务器上建立一个本地数据库 db。若是表 Test 不存在,则建立一个,而后插入测试数据(Monkey! 和时间)。代码从数据库获取数据,并在浏览器中以警告的形式呈现出来。
想像一下可能发生的结果!
Graphic Interchange Format (GIF) 和 Joint Photographic Experts Group (JPEG) 图像格式都已过期了:Portable Network Graphic (PNG) 是将来流行的格式。固然,您能够说 GIF 和 JPEG 已经消亡,或者 PNG 没有任何缺陷,可是全部事物都有各自的优缺点,PNG 以最佳的文件大小提供了出色的质量。所以,若是进行选择的话,应该尽量使用 PNG 图像。
当统称为 Asynchronous JavaScript + XML (Ajax) 的技术在两年前出现时,这些技术为处理页面请求和响应提供了一种革命性方法。然而,拨号用户可能历来没机会体验其真正的优点,由于在许多情形下,Ajax 须要在浏览器与服务器之间大量通讯。所以,若是您可以保持 Ajax 调用简短和准确,能够避免用户花费无止尽的时间来等待元素刷新或响应。
若是不能进行简短的 Ajax 调用,或者若是这些调用不能提供指望的结果,能够考虑一种替代方法:进行一次大的 Ajax 调用来获取所需的一切内容,而后让客户机在本地处理数据。经过这种方式,客户机只需等待一次(获取传入的数据),可是在此以后(当浏览器与服务器之间没有必要通讯时),处理速度将更快。固然,还有大量 Ajax 优化技术,本教程没法一一列出。若是想要了解关于 Ajax 的更多信息,请查看 参考资料。
还有一个常常被遗忘的经常使用技巧。尽管清醒的 Web 开发人员一般会在启动应用程序以前对其进行测试,可是有时候测试会使他们不那么重视维护任务,或者新功能添加得太快,而且未通过充分考虑或测试。结果,余下的脚本减缓了应用程序的速度。
若是您添加一项新功能,能够首先在沙箱里(彻底脱离了应用程序的其他部分)进行测试,查看它做为单个函数的行为。经过这种方式,您能够反复检查,并分析性能和响应时间,无需考虑 Web 应用程序的其他部分。而后,当新功能的行为符合预期时,能够将其引入到应用程序的其他部分中,运行其余测试,保证功能自己的行为符合预期。
在许多场景中,自我检讨是一个不错的建议。幸运的是,在开发过程当中,咱们可使用工具来帮助检讨,并尽量客观地进行实践。像 JSLint(参见 参考资源)这样的工具的价值是没法衡量的,尽管其站点宣称它 “可能令您备受挫折”,由于它向您提供了全部的潜在代码缺陷,这些缺陷不但使调试更加困难,并且可能致使更长的响应时间。
您不须要像完美主义者那样追求天衣无缝的 JavaScript 代码。可是,许多开发人员没有认真对待代码分析,一般在开发过程当中跳过了这个步骤。不幸的是,错误和糟糕的编码实践不只不太专业,并且可能减缓应用程序的速度。当浏览器忙于应付错误和糟糕的编码实践时,加载不只须要更多时间,还会致使难以调试的错误。
所以,若是想要得到良好的代码,能够考虑使用代码分析工具。有许多不一样的工具可供使用,可是最适合 JavaScript 语言的工具非 JavaScript Lint 莫属,它也叫作 JSLint(参见 参考资料)。也可使用 Firebug,可是 JSLint 更加正式,它包含在 YSlow 中。
检查孤立的文件和丢失的图像是一种明智之举。大部分 Web 开发人员都会检查错误的文件引用,可是这里仍然须要说明一下。丢失的文件容易引发各类问题,由于它们会致使 “The image/page cannot be displayed” 之类的错误消息。可是在网页速度优化方面,它们具备更大的缺陷:当浏览器寻找丢失的或孤立的文件时,它会消耗资源,这不可避免地会致使页面处理速度变慢。所以,请检查孤立或丢失的文件,包括拼写错误的文件名。
YSlow Firebug 扩展使主观的网页分析日渐被淘汰。YSlow 使用 Yahoo! 起草的面向高性能网站的权威规则,分析网页并告诉您它们变慢的缘由。
YSlow 是一个相对较小但很是有用的 Firefox 扩展。当启动 YSlow 时,该扩展在浏览器的下半部分中打开,如 图 4 所示。
图 4 显示了 Performance 视图,能够在其中看到 YSlow 如何评估您的网页的性能,还可以看到该扩展检测到的问题。单击列表中的一个连接将打开一个页面,其中解释了相应的错误。若是存在能够改进的页面组件,YSlow 会给出改进建议。
在 Inspect 视图中,如 图 5 所示,您能够逐一分析元素来剖析页面。Inspect 视图的一个最有用的功能是,当您在页面上移动鼠标指针时,它会自动刷新,所以您无需经过滚动代码内容来查找须要检查的行。
从 Stats 视图的名称能够猜想到,它(如 图 6 所示)显示与当前页面有关的统计数据。这些数据包括空的和主要的缓存和 cookie。
Components 视图(如 图 7 所示)列出了当前页面上的组件。显示的与每一个组件有关的数据包括文件类型和路径、页面过时时间以及 HTTP 响应报头。单击一个组件能够将其打开,以供查看。单击一个列标题能够按升序或降序对表进行排序。
YSlow 是一个较小的、有用的扩展,能够在提升页面加载速度方面为您提供许多帮助。若是您之前未使用过它,那么如今应该使用了。
优化网页的加载速度并不复杂。实际上,您一般能够垂手可得地实现速度优化。若是遵循本文中介绍的技巧以及 Web 开发最佳实践,那么无需采用其余措施就能够提升页面的加载速度。
将大量页面优化技巧收集到一块儿很简单,我但愿本文的资源具备必定的价值。可是,若是您认为速度优化技巧只有这里列出的这些,那么您将惊奇地发现远远不止这些。可是,即便您仅遵循这 20 多个技巧,您的页面的加载速度也会更快,您的用户也会更惬意 —— 不管他们经过拨号仍是专用的宽带上网。
http://www.ibm.com/developerworks/cn/web/wa-speedweb/