发布时间:2018 年 8 月 17 日
本指南审视 PageSpeed Insights 规则背景:优化关键渲染路径时的注意事项以及原因。
消除阻塞渲染的 JavaScript 和 CSS
要以最快速度完成首次渲染,需要最大限度减少网页上关键资源的数量并(尽可能)消除这些资源,最大限度减少下载的关键字节数,以及优化关键路径长度。
优化 JavaScript 的使用
默认情况下,JavaScript 资源会阻塞解析器,除非将其标记为 async
或使用专门的 JavaScript 代码段进行添加。阻塞解析器的 JavaScript 会强制浏览器等待 CSSOM 并暂停 DOM 的构建,继而大大延迟首次渲染的时间。
首选使用异步 JavaScript 资源
异步资源不会阻塞文档解析器,让浏览器能够避免在执行脚本之前受阻于 CSSOM。通常,如果脚本可以使用 async
属性,也就意味着它并非首次渲染所必需。可以考虑在首次渲染后异步加载脚本。
避免同步服务器调用
使用 navigator.sendBeacon()
方法限制 XMLHttpRequest 在 unload
处理程序中发送的数据。因为许多浏览器都对此类请求有同步要求,所以可能减慢网页转换速度,有时还很明显。以下代码展示了如何使用 navigator.sendBeacon()
向 pagehide
处理程序(而不是 unload
处理程序)中的服务器发送数据。
<script>
function() {
window.addEventListener('pagehide', logData, false);
function logData() {
navigator.sendBeacon(
'https://putsreq.herokuapp.com/Dt7t2QzUkG18aDTMMcop',
'Sent by a beacon!');
}
}();
</script>
fetch()
方法提供了一种更好的数据异步请求方式。fetch()
使用 Promise 而非多个事件处理程序来处理响应。不同于对 XMLHttpRequest 的响应,fetch()
响应是 stream 对象。这意味着调用 json()
也会返回 Promise。
<script>
fetch('./api/some.json')
.then(
function(response) {
if (response.status !== 200) {
console.log('Looks like there was a problem. Status Code: ' + response.status);
return;
}
// Examine the text in the response
response.json().then(function(data) {
console.log(data);
});
}
)
.catch(function(err) {
console.log('Fetch Error :-S', err);
});
</script>
fetch()
方法也可处理 POST 请求。
<script>
fetch(url, {
method: 'post',
headers: {
"Content-type": "application/x-www-form-urlencoded; charset=UTF-8"
},
body: 'foo=bar&lorem=ipsum'
}).then(function() { // Additional code });
</script>
延迟解析 JavaScript
为了最大限度减少浏览器渲染网页的工作量,应延迟任何非必需的脚本(即对构建首次渲染的可见内容无关紧要的脚本)。
避免运行时间长的 JavaScript
运行时间长的 JavaScript 会阻止浏览器构建 DOM、CSSOM 以及渲染网页,所以任何对首次渲染无关紧要的初始化逻辑都应延后执行。如果需要运行较长的初始化序列,请考虑将其拆分为若干阶段,以便浏览器可以间隔处理其他事件。
优化 CSS 的使用
CSS 是构建渲染树的必备元素,首次构建网页时,JavaScript 常常受阻于 CSS。确保将任何非必需的 CSS 都标记为非关键资源(例如打印和其他媒体查询),并应确保尽可能减少关键 CSS 的数量,以及尽可能缩短传送时间。
将 CSS 放在文档标头处
尽早在 HTML 文档内指定所有 CSS 资源,以便浏览器尽早发现 <link>
标记并尽早发出 CSS 请求。
避免使用 CSS import
一个样式表可以使用 CSS import (@import
) 指令从另一样式表文件导入规则。不过,应避免使用这些指令,因为它们会在关键路径中增加往返次数:只有在收到并解析完带有 @import
规则的 CSS 样式表之后,才会发现导入的 CSS 资源。
内嵌阻止呈现的 CSS
为获得最佳性能,您可能会考虑将关键 CSS 直接内联到 HTML 文档内。这样做不会增加关键路径中的往返次数,并且如果实现得当,在只有 HTML 是阻塞渲染的资源时,可实现“一次往返”关键路径长度。