好的...所以我正在运行一个小测试来尝试从 Google PageSpeed 获得 100/100。我们有以下网站 - https://redwing.media
我还有一件事要做,那就是把 CSS 去掉(作为它的渲染阻塞内容),允许内容加载,然后使用 JavaScript 来拉入 CSS。如果我根本不加载 CSS,我会得到100/100 PageSpeed。我已经把我所有的关键 CSS 放在了头脑中。
<style>
BODY { background-color: #1B1719; }
BODY > * { display: none; }
</style>
所以,我使用谷歌推荐的在内容加载后加载 CSS 的方法(见这里) -
<noscript id="deferred">
<link rel="stylesheet" type="text/css" href="assets/css/screen.css">
</noscript>
<script>
var loadDeferredStyles = function() {
var addStylesNode = document.getElementById("deferred");
var replacement = document.createElement("div");
replacement.innerHTML = addStylesNode.textContent;
document.body.appendChild(replacement)
addStylesNode.parentElement.removeChild(addStylesNode);
};
var raf = requestAnimationFrame || mozRequestAnimationFrame ||
webkitRequestAnimationFrame || msRequestAnimationFrame;
if (raf) raf(function() { window.setTimeout(loadDeferredStyles, 0); });
else window.addEventListener('load', loadDeferredStyles);
</script>
现在,当我运行 PageSpeed 洞察力时,我直接回到了 85/100 的移动页面速度,因为我的 screen.css 显然是渲染阻塞...
这是怎么回事?我正在使用谷歌推荐的解决方案!
这是我正在建设的网站 - https://redwing.media/