我想这已经被一次又一次地问到了,但我还没有看到我正在寻找的答案。
我用 HTML 文件和 CSS 文件做一些简单的测试,试图阻止页面渲染阻塞 CSS,通过页面洞察(谷歌)运行网站
现在我看到了这样的答案:
<link rel="stylesheet" href="style.20180530.css?ver=1.0" media="none" onload="if(media!='all')media='all'">
我见过这样的答案:
<link href="https://fonts.googleapis.com/css?family=Roboto:300,700" rel="preload" onload="this.rel='stylesheet';this.removeAttribute('onload');" as="style">
对于谷歌字体,我都很好!但是对于页面的主要样式而言,我认为看到没有样式的页面然后突然加载它们并不是一个好的用户体验。
显然,您可以通过将全部内容作为内联样式来消除 CSS 的任何阻塞,但我再次认为这不是一个好习惯,您将所有样式输出到 HTML 页面,而不是通过样式表加载它们。
我已经看到网站实际上加载了这样的样式:
<link rel='stylesheet' id='main-css' href='./style.2018052108.css?ver=4.9' type='text/css' media='all' />
这是一个指向页面洞察速度测试的链接。我知道该网站正在运行 wordpress。如果您查看页面源代码,它的使用与我上面使用的完全相同。
而且他们根本没有渲染阻塞......如何?
我在 https 我正在使用 cloudflare 并且我的样式表被压缩并且只有大约24 字节并且我仍然遇到渲染阻塞。
- 为什么?
- 如何避免?