含有外部 css 文件的渲染流水线

上图中,请求 HTML 数据和构建 DOM 中间有一段空闲时间,这段时间可能成为页面渲染的瓶颈。DOM 构建结束后,css 文件还未下载完成这段时间内,渲染流水线一直在等待,因为下一步是合成布局树。合成布局树需要 CSSOM 和 DOM,所以需要等待 CSS 加载结束并解析为 CSSOM。这种情况下,CSS 没有阻塞 DOM 的生成。

CSSOM 的作用

提供给 JS 操作样式表的能力

为布局树合成提供基础的样式信息

含有内联 JS 和 外部 CSS 页面的渲染流水线

从上图中可以看到,构建 DOM 过程中遇到 JS 会停止构建,去解析执行 JS,因为 JS 可能会修改当前 DOM。

在执行 JS 脚本之前,若页面中包含外部 css 或内联的 css,渲染引擎需要将他们提前转为 CSSOM,因为 JS 有修改 CSSOM 的能力,所以在 JS 执行前,还要依赖 CSSOM。 这意味着 CSS 在部分情况下也会阻塞 DOM 生成。

含有外部 JS 和 CSS 页面的渲染流水线

请求到的 HTML 数据在预解析过程中,检测到有外部 JS、CSS 文件需要下载,同时发起两个文件的下载请求,下载时间不是重叠的,是按照最久的那个来算。

不管 CSS,JS 谁先到达,都要先等到 CSS 文件下载并生成 CSSOM,然后执行 JS 脚本,最后构建 DOM、布局树、绘制页面。

影响页面展示因素及优化策略

从输入 URL 到页面首次展示的三阶段:

请求发出去后,到提交数据阶段,此时页面展示的还是之前页面的内容。

提交数据后,渲染进程会创建一个空白页面,这段时间称为 解析白屏 ,等待 CSS 和 JS 文件的加载完成,生成 CSSOM 和 DOM,然后合成布局树、XXX 等步骤准备首次渲染。

首次渲染完成后,就开始进入完整页面的生成阶段,页面会一点点被绘制出来。

最影响用户体验的就是第二阶段,包括解析 HTML、下载 CSS、下载 JavaScript、生成布局树、绘制页面等操作。

优化策略

内联 CSS、JS,等到 HTML 下载好后便可直接开始渲染。

尽量减少文件大小,webpack 移除注释、压缩文件。

将一些不需要在解析 HTML 阶段使用的 JS 标上 async 或 defer。

对于大的 CSS 文件,可以通过媒体查询,将其拆分为不同用途的 CSS 文件,只在特定场景下加载。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

html自动切换图片怎么白屏,CSS 如何影响首次加载时的白屏时间的解决方法相关推荐

  1. Matlab在win10运行不出图片,win10系统网页图片加载不出来的六种原因及解决方法...

    大家经常会使用浏览器来浏览一些站点查看图片,最近有的用户说win10系统打开网页时发现页面图片加载不出来,只显示一个×标志,让人百思不得其解,其实出现此问题可能是网速过低,或者浏览器设置里面没有开启相 ...

  2. 未来教育c语言加载不出来图片,win10系统网页图片加载不出来的六种原因及解决方法[多图]...

    大家经常会使用浏览器来浏览一些站点查看图片,最近有的用户说win10系统打开网页时发现页面图片加载不出来,只显示一个×标志,让人百思不得其解,其实出现此问题可能是网速过低,或者浏览器设置里面没有开启相 ...

  3. 解决bootstrap table刷新加载时白色闪屏问题

    根据项目需要,把bootstrap table都改成了蓝色的风格,但是今天测试的时候发现了一个小的问题.每次刷新加载的数据的时候,总是会有一闪而过的白屏.很影响交互效果,这个时候,需要找到bootst ...

  4. dw html5中怎么设置图片自动切换,DW制作九宫格全屏亮灯轮播图片且自动切换图片教程...

    本文介绍的是利用DW制作九宫格全屏亮灯轮播图片并且可以自动切换图片,而且点击图片时还会亮灯,推荐过来,大家一起来学习吧! 软件名称:Adobe Dreamweaver CS3 官方中文安装版软件大小: ...

  5. 52 jQuery-使用slideToggle()方法的动画效果自动切换图片的高度

    1.效果图 2.HTML代码 <!DOCTYPE html> <html> <head><meta charset="utf-8"> ...

  6. React Native 首次加载白屏优化

    RN首次加载都会有个白屏过程,一般都会有500ms+的白屏时间,原生页面开发同样的页面会能够快速显示而在RN页面中有个明显的等待过程,这个会影响用户体验. 1.使用过渡页面 简单处理可以在白屏过程中加 ...

  7. [html] iOS下页面如何启动加载时显示画面图片?如何设置大小?它有什么好处?

    [html] iOS下页面如何启动加载时显示画面图片?如何设置大小?它有什么好处? <link rel="apple-touch-startup-image" href=&q ...

  8. js控制css 加载,CSS样式表的加载对于DOM解析,渲染,JS执行的阻塞问题

    CSS加载问题 css加载会不会阻塞DOM树的解析? css加载会不会阻塞DOM树的渲染? css加载会不会阻塞后面js语句的执行? css阻塞 h1 { color: red !important ...

  9. img实现图片加载前默认图片,加载时替换真实图片,加载失败时替换加载失败图片

    文章目录 前言 一.加载前 二.加载成功 三.加载失败 总结 前言 开发过程中,我们希望图片在加载失败的时候会替换成加载失败的图片,同时为了更好的体验,加载前最好也要有一张占位图片,即实现加载前显示一 ...

最新文章

  1. Android 判断某个服务是否正在运行
  2. R语言使用pROC包绘制ROC曲线实战:roc函数计算AUC值、plot.roc函数绘制ROC曲线、添加置信区间、为回归模型中的每个因子绘制ROC曲线并在同一个图中显示出来
  3. docker-compose 命令
  4. 连续三年蝉联第一,Flink 荣膺全球最活跃的 Apache 开源项目
  5. android10热点验证身份,在 Android 上使用 Microsoft 进行身份验证
  6. Spatial Transformer Networks(STN)详解
  7. 点击时候确定某个元素 js_某空气质量监测平台 JS反爬
  8. c语言中输入字符用什么作用是什么意思,C语言编程问题
  9. bzoj千题计划287:bzoj1228: [SDOI2009]ED
  10. Android视频播放
  11. Python学习之路3 - 字符串操作字典
  12. iOS开发日记29-UIAlertController
  13. java md5在线解密免费_Java MD5如何解密?
  14. 8个免费、可商用的视频素材网站,一定要收藏
  15. waiting for headers
  16. Android实现欢迎界面
  17. 用户分析(AARRR)
  18. 腾讯云TCA开发工程师认证考试
  19. 7-3 拍7令三 (100 分)
  20. 【NISP一级】1.3 网络空间安全政策与标准

热门文章

  1. P202 例9-2 以如图9-8所示的带权有向图为例,编写测试上述图的深度优先和广度优先遍历函数的程序。
  2. python中functools_Python functools模块完全攻略
  3. 第三届进博会世界第一运动品奢侈品牌自行车辐轮王中国新机会
  4. Yii2.0 游客访问限制
  5. 中专学的计算机大学可以报什么专业,初中孩子成绩不好,上中职学这五个专业,不愁就业又能考大学...
  6. 4个国内免费DNS服务商
  7. python randint函数用法_使用random函数实现randint函数的功能
  8. 论文简述Reversible Data Hiding in Encrypted Images with Two-MSB Prediction加密图像可逆信息隐藏算法
  9. 体验了一下火爆全球的 ChatGPT,我震惊了
  10. 生产者消费者问题-代码详解(Java多线程)