编写快速加载的 HTML 网页的技巧
以下技巧都是基于通用的知识和经验。
一个好的页面不仅要给访客提供一个更有交互性的站点,同时也需要降低你的服务器压力和网络请求。后者对于那些高访问量的站点,或在有爆炸性新闻出现等特殊情况下会出现流量突增的站点来说尤为关键。
页面加载性能的优化不仅仅是针对那些带宽有限的拨号上网或移动设备用户需要看的内容,对于提供给宽带用户访问的内容同样重要并且可以导致巨大的提升,哪怕对于那些拥有最快网速的访客。
技巧
减小页面的大小
直至今日,页面的大小仍是页面加载性能的最重要因素。
通过消除不必要的空白和注释(通常称为最小化)以及将内联脚本和 CSS 移至外部文件来减少页面大小,可以提高下载性能,而无需对页面结构进行其他改动。
诸如 HTML Tidy 这类的工具可以从有效的 HTML 源文件中自动截去行首空格和额外的空行,其他工具则可以通过重新格式化源代码来“压缩”JavaScript 或者通过混淆源码将长标识符替换为短标识符来减小文件大小。
最小化文件数量
减少一个页面引用的文件数量可以降低在下载一个页面的过程中需要的 HTTP 请求数量,从而减少这些请求的收发时间。
根据其缓存设置,浏览器可能会为每个所引用的文件发送一个带 If-Modified-Since
标头的请求给 web 服务器,以查询这些文件自上次加载后是否有被修改。查询引用文件上次修改时间会花费太多时间,导致网页首屏延迟,这是因为在渲染页面之前浏览器必须确认每个文件的修改时间。
如果你在 CSS 中经常使用背景图片,可以通过将图片合并为一张图片(即精灵图)来减少 HTTP 查找次数。然后,每次需要使用背景图片时,只需应用相同的图片,并适当调整 x/y 坐标即可。这种技术最适用于尺寸有限的元素,并不适用于所有背景图片的使用。不过,减少 HTTP 请求和单张图片缓存有助于缩短页面加载时间。
使用内容分发网络 CDN
减少域名查询
每个独立的域名都会消耗 DNS 查询的时间,页面加载时间会随着独立域名数量、CSS 链接数量、JavaScript 还有图片资源的数量增加而增加。
这条可能算不上实用,然而,在你的页面中尽量少的使用来自不同域名的资源链接。
缓存重用的内容
确保任何内容可以被缓存,并且拥有一个合理的有效期。
尤其要注意 Last-Modified
标头。它可以实现高效的页面缓存;通过这个标头,可以向用户代理传达它想要加载的文件的相关信息,例如文件的最后修改时间。大多数 web 服务器会根据存储在文件系统中的最后修改日期,自动将 Last-Modified
标头附加到静态页面(如 .html
、.css
)上。对于动态页面(如 .php
、.aspx
),当然无法做到这一点,因此不会发送标头信息。
因此,特别是对于动态生成的页面,对这一主题进行一些研究是有益的。这可能会涉及到一些问题,但对于通常无法缓存的页面来说,这将会节省大量的页面请求。
更多信息:
高效地排列页面组件
在页面最初显示时,会首先下载页面内容以及所需的 CSS 和 JavaScript,这样在页面加载时用户可以最快获得外观的反馈。由于内容通常都是文本,有利于在传输过程中压缩,从而为用户提供更快的响应。
任何需要在页面加载完成后才能使用的动态功能,都应先禁用,然后在页面加载完成后再启用。这将使 JavaScript 在页面内容之后加载,从而改善页面加载的整体外观。
减少内联脚本的数量
内联脚本对页面加载的影响很大,因为解析器必须假定内联脚本可能会在解析过程中修改页面结构。减少内联脚本的使用,尤其是减少使用 document.write()
来输出内容,可以提高页面的整体加载速度。为现代浏览器使用 DOM API 来操作页面内容,而不是使用 document.write()
。
使用现代 CSS 和有效标记
使用现代 CSS 减少标记的用量,可以减少对(间隔)图片的需求。在布局方面,图片通常可以用具有样式的文本来替代,这样会“节省”许多资源。
使用合法标记还有其他优点。首先,浏览器在解释 HTML 时无需做错误校正(除了一些哲理性的问题,例如,是允许用户输入格式不一致,然后再用程序“校准”或统一化呢?还是加强约束规则,限制用户输入的格式?)。
再者,合法标记可以让那些给你的网站做预处理的工具功能最大化。例如,HTML Tidy 可以移除空白符和可选的结束标记;然而,在有严重的错误标记的网页中这些工具便无法工作。
给内容分块
最小化和压缩 SVG 资源
大多数绘图应用程序生成的 SVG 通常包含不必要的元数据,这些元数据可以删除。配置服务器,对 SVG 资源应用 gzip 压缩。
最小化和压缩图片
大图像会导致页面加载时间延长。请考虑在将图片添加到页面之前对其进行压缩,使用 Photoshop 等图片处理工具内置的压缩功能,或使用 Compress Jpeg 或 Tiny PNG 等专门工具。
指定图像和表格的大小
如果浏览器能立即确定图像和表格的高度和/或宽度,就能显示网页而无需重新调整内容。这不仅能加快页面的显示速度,还能防止页面加载完成后出现令人讨厌的布局变化。因此,应尽可能为图片指定 height
和 width
。
表格可以使用 CSS 选择器:综合性能:
table-layout: fixed;
并且用用 <col>
和 <colgroup>
元素来指定列宽。
对图片使用懒加载
默认情况下,图片是立即加载的;也就是说,一旦图片在 HTML 中被处理,就会立即获取并渲染。所有立即加载的图片都会在窗口的 load
事件发送之前得到渲染。如果改用懒加载图像,浏览器就会暂缓加载图像,直到需要绘制可视视口时再加载。
要将图片标记为“懒加载”,可指定其 loading
属性的值为 lazy
。这样设置后,只有在需要时才会加载图片。
<img src="./images/footerlogo.jpg" loading="lazy" alt="MDN logo" />
请注意,load
事件触发时,懒加载的图片可能不可用。可以通过检查 complete
布尔属性的值是否为 true
来确定给定图片是否已加载。
合理的选择用户代理
为使页面设计得到极大提升,应确保在工程中指定一个合理的用户代理(user agent)。不要奢求你的内容在所有浏览器中都完美的展现,特别是在那些低版本的浏览器中。
理想情况下,你的页面运行的最小环境要基于现代浏览器,这个浏览器起码要支持一些相关的标准。可以是最近版本的 Firefox、IE、谷歌 Chrome、Opera 和 Safari。
但要注意的是,本文列出的许多技巧都是常识性技术,适用于任何用户代理,并可应用于任何网页,与浏览器支持要求无关。
尽可能使用 async 和 defer
页面结构示例
参见
- 书籍:Andy King 撰写的让你的站点访问更快
- 非常棒、讲的很全的加快站点访问的最佳实践资料(来自 Yahoo!)
- 用来分析和优化的工具:Google PageSpeed 工具