miniui 样式第一次加载不出来_web前端入门到实战:异步加载CSS最简单的实现方式

95330a9297b63983a789624c1ab42c06.png

我们想提高网页性能的最有影响力的措施之一,就是以不延迟网页渲染的方式加载CSS

在默认情况下,浏览器在加载CSS时将终止页面的样式呈现(同步加载),也就是加载CSS会阻塞DOM树的渲染(但并不会阻塞DOM树的构建),可以简单理解为:当在加载CSS的同时,也在构建DOM树,只是没有应用上样式。

在学习上有什么疑问随时可以咨询我,与大家分享互联网web前端实战操作,无论你是否有基础,我都欢迎。点:前端教学分享

渲染流程

简单过一遍浏览器渲染的流程:

  1. 加载HTML资源
  2. 解析HTML
  3. 加载CSS资源,同时构建DOM树
  4. 解析CSS,同时渲染DOM树

CSS文件过大,就会停留在第3步,所以网速慢时,打开网站的时候经常遇到没有样式的情况。

所以我们需要先加载部分CSS首屏需要用到的CSS),其他优先级比较低的CSS就以异步的方式加载。与script元素不同,没有asyncdefer属性可以简单地应用于link元素,但是可以模拟。

异步加载

1. 利用媒体查询

设置一个当前浏览器不支持的值:

<link rel="stylesheet" href="./index.css" media="none" onload="this.media='all'">

这样浏览器将会异步加载这个CSS文件(优先度比较低),在加载完毕之后,使用onload属性将link的媒体类型设置为all,然后便开始渲染。

如果有如下代码:

<link rel="stylesheet" href="./index2.css" media="none" onload="this.media='all'">
<link rel="stylesheet" href="./index1.css">

浏览器加载优先级如下:

07e7c8bdfcaadbeb9d33e62a6a1056cb.png

又或者有如下代码:

<link rel="stylesheet" href="./index1.css" media="screen and (max-width: 800px)">
<link rel="stylesheet" href="./index2.css" media="screen and (min-width: 800px)">

刷新页面时,如果视窗宽度小于800px,那么优先加载index1.css,如果大于800px,则相反:

500cf4eb30900a3fbc2b63dbdc6dcc41.gif

总结:媒体查询不匹配的样式优先级低 。

2. 提前加载资源

这个跟上述类似,但是优先级是最高的,不过还是异步加载,不会阻塞DOM的渲染,只是浏览器支持度比较低 。

<link rel="preload" href="./index.css" as="style">

告诉浏览器"请提前加载好此资源,我后面会用到!"。当用到的时候,浏览器便从缓存中拿取 。

所以正确操作跟媒体查询一样:

<link rel="preload" href="./index.css" as="style" onload="this.rel='stylesheet'">

当然,该属性还可以应用于其他资源,当你需要用到这些资源的时候,浏览器会直接从缓存中拿,不再次发送请求了。

<link rel="preload" href="./index.js" as="script">
<link rel="preload" href="./index.png" as="image">
<link rel="preload" href="./index.mp4" as="video" type="video/mp4">

3. 捞仔写法

let link = document.createElement("link");
link.rel = "stylesheet";
link.href = "./index1.css";

document.head.appendChild(link);

总结

重要样式使用同步加载(常规写法),优先级低的则使用异步加载,异步加载不会阻塞页面的渲染。

越来越多的人发现,可能只需要简单的HTML方法,而简单往往是最好的。

<link rel="stylesheet" href="./main.css">
<link rel="stylesheet" href="./other.css" media="none" onload="this.media='all'">
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值