iis服务器助手广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >深入了解JavaScript阻塞渲染
  • 116
分享到

深入了解JavaScript阻塞渲染

2024-04-02 19:04:59 116人浏览 薄情痞子
摘要

目录到底几个线程主线程的任务Parse htmlRecaculate StyleLayoutUpdate Layer TreePaintjs为啥阻塞渲染总结前言: 在中文社区,这么多

前言:

在中文社区,这么多年一直流传一个说法:JS线程负责执行JSGUI渲染线程负责渲染,这两者是互斥的,所以JS执行时会阻塞渲染。但随着Dev Tools使用的增多,逐渐开始怀疑以上说法。本文会以实际案例来解释为什么JS阻塞渲染。

到底几个线程

在讲解JS线程与GUI线程互斥的文章中,通常会列出渲染进程包含的线程,比如:

  • GUI渲染线程
  • JS引擎线程
  • 事件触发线程
  • 定时触发器线程
  • Http请求线程

但是,我们以百度的搜索页举例,打开PerfORMance面板开启录制:

上图录制结果中:

  • Chrome_ChildioThread对应IO线程的任务记录,用户输入、网络、设备相关事件都与他相关
  • Raster记录光栅化线程池任务、GPU记录GPU合成位图的任务、Compositor记录合成线程的任务执行,以上三者都与浏览器渲染相关
  • Main记录渲染进程的主线程中的任务

从这个角度看,浏览器实际的线程情况与那些GUI线程相关的文章描述的并不相同。

主线程的任务

接下来,让我们进入Main。红线框内长短不一的灰色块,就是主线程中执行的任务。

注意看红框内的绿色块FP,代表First Paint(首次绘制):

那么在首次绘制前都要执行什么任务呢?可以看到主要有3个Task(任务):

第一个任务是请求HTML数据:

Parse HTML

当请求回HTML字节流后,开始第二个任务,将HTML字节流解析为DOM,这个任务的名字就是图中的蓝色块Parse HTML

注意其中有些执行时长不一的Evaluate Script,这些是解析DOM树过程中遇到的JS代码。

DOM树中可以看到这些阻塞DOM树生成的JS脚本:

他们的存在显著拉长了Parse HTML的用时。

Recaculate Style

解析完DOM树(蓝色Parse HTML)后,下一个任务是紫色Recaculate Style

他负责将HTML中的CSS样式(外联、内联)输出为styleSheetsstyleSheets有两个作用:

  • 可以与DOM树结合为页面带来样式
  • JS可以操作styleSheets改变页面样式

我们可以从控制台打印document.styleSheets直观感受他的存在:

Layout

有了DOM树与styleSheets,接下来需要为视图中可见部分生成一棵树(比如display: none部分就不需要在这棵树中显示)。

这个任务是紫色Layout

Update Layer Tree

用户看到的页面实际是由多层页面重叠后的结果,开发者可以用很多手段(比如z-index)改变某部分的层级。

比如滚动条就会形成自己独立的层级:

既然是多层结构,那么就需要更新每层的信息,这个任务是紫色的Update Layer Tree

Paint

我们可以发现,在FP之前,Update Layer Tree之后只剩下Paint这一任务了:

从字面意义讲,这就是绘制么?并不是。

Paint的任务是整理每一层页面的绘制信息,构成绘制列表,这些数据会交给合成线程负责后续绘制操作。

可以发现,具体的绘制操作是交由合成线程完成,他与JS所在线程(主线程)并不是互斥的。

JS为啥阻塞渲染

我们现在知道,JS执行与Paint任务都发生在主线程。

渲染被阻塞的原因很明显:因为Paint任务没有及时执行,即绘制列表没有及时提交给合成线程。

之所以没有及时执行,可能是因为JS执行时间过长,导致这一帧没有时间执行Paint

比如,我们打开B站,记录下主线程的任务。

可以看到,有个JS执行时长达到231.88ms,超过了一帧的时间,在此期间主线程就没时间执行Paint了:

总结

JS之所以阻塞渲染,是因为JS执行与渲染相关任务都在争夺主线程有限的资源。当JS执行时间过长,渲染相关任务就没时间执行了。

到此这篇关于深入了解javascript阻塞渲染的文章就介绍到这了,更多相关JS阻塞渲染 内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 深入了解JavaScript阻塞渲染

本文链接: https://www.lsjlt.com/news/150990.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 深入了解JavaScript阻塞渲染
    目录到底几个线程主线程的任务Parse HTMLRecaculate StyleLayoutUpdate Layer TreePaintJS为啥阻塞渲染总结前言: 在中文社区,这么多...
    99+
    2024-04-02
  • CSS会阻塞页面渲染吗
    这篇文章给大家分享的是有关CSS会阻塞页面渲染吗的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。原理解析那么为什么会出现上面的现象呢?我们从浏览器的渲染过程来解析下。 不同的浏览器使用的内核不同,所以他们的渲染过程...
    99+
    2023-06-08
  • Flutter渲染原理深入解析
    目录Widget Element RenderObject之间的关系1 Widget2 Element3 RenderObject4 结合图说一下其三者的关系5 一些小问题Widge...
    99+
    2023-05-15
    Flutter渲染原理 Flutter渲染
  • 深入解析Canvas的渲染模式
    Canvas的renderMode详解,需要具体代码示例 在Unity中,Canvas是实现2D UI最基础和关键的组件。Canvas在渲染过程中有两种不同的模式:Screen Space和World Space。这些渲染模式在...
    99+
    2024-01-17
    Canvas 详解
  • 深入了解CSS布局重新计算和渲染的机制
    CSS回流(reflow)和重绘(repaint)是网页性能优化中非常重要的概念。在开发网页时,了解这两个概念的工作原理,可以帮助我们提高网页的响应速度和用户体验。本文将深入探讨CSS回流和重绘的机制,并提供具体的代码示例。 一...
    99+
    2024-01-26
    机制 重绘 CSS回流
  • Java并发编程之阻塞队列深入详解
    目录1. 什么是阻塞队列2. 阻塞队列的代码使用3. 生产者消费者模型(1)应用一:解耦合(2)应用二:削峰填谷(3)相关代码4.阻塞队列和生产者消费者模型功能的实现1. 什么是阻塞...
    99+
    2024-04-02
  • React更新渲染原理深入分析
    目录ScheduleLegacy modeConcurrent mode时间切片任务的优先级获取最先处理的taskReconcile前置知识从jsx到dom双缓存fiber tree...
    99+
    2022-12-23
    React更新渲染 React更新 React渲染
  • Vue3渲染器与编译器深入浅析
    目录渲染器相关概念渲染器阶段分析mount挂载阶段patch阶段简单实现编译器相关概念总结渲染器 相关概念 渲染器是Vue框架性能的核心,Vue3的渲染器不仅包含传统的Diff算法...
    99+
    2023-02-01
    Vue3渲染器编译器 Vue渲染编译
  • 对Canvas渲染模式进行深入分析
    深入解析Canvas的渲染模式,需要具体代码示例 一、引言Canvas是HTML5标准中的一个重要元素,可以实现基于像素的图形渲染。它提供了丰富的API,使得开发者可以通过JavaScript在浏览器上绘制2D图形、动画和游戏等...
    99+
    2024-01-17
    Canvas 解析 渲染模式
  • 深入探讨Go语言实现阻塞的机制
    Go语言是一种轻量级的并发编程语言,其强大的并发特性使其在处理大规模并发任务时表现出色。在Go语言中,阻塞是一种常见的编程模式,可以通过通道(channel)和goroutine来实现...
    99+
    2024-04-02
  • JavaScript 渲染性能优化:从入门到精通
    JavaScript 渲染性能优化是一门技术,可以帮助你提高 JavaScript 代码的性能,从而使你的网页加载速度更快,并提供更好的用户体验。 1. 减少 JavaScript 文件的大小 JavaScript 文件的大小是影响页面...
    99+
    2024-02-09
    JavaScript 渲染性能 优化 代码 速度 体验
  • 带你了解Nodejs中的非阻塞异步IO
    以上就是带你了解Nodejs中的非阻塞异步IO的详细内容,更多请关注编程网其它相关文章!...
    99+
    2023-05-14
    I/O模型 node
  • 了解Canvas渲染模式的应用领域
    探究Canvas渲染模式的应用场景 引言:随着Web技术的不断发展,Canvas渲染模式在Web开发中得到了广泛的应用。Canvas是一种基于HTML5的图形绘制API,它允许我们在浏览器中通过JavaScript脚本来绘制2D...
    99+
    2024-01-17
    Canvas 应用场景 渲染模式
  • 深入了解JavaScript发布订阅模式
    目录发布订阅模式的基本原理发布订阅模式和观察者模式的区别对象关系解耦发布订阅模式的应用场景生产者 & 消费者关系消息队列自定义事件系统结语JavaScript 发布订阅模式(...
    99+
    2023-05-19
    JavaScript 发布订阅模式 JavaScript 订阅模式
  • 深入了解javascript原型和原型链
    目录一、什么是原型二、prototype三、__proto__四、constructor五、实例与原型六、原型的原型七、原型链一、什么是原型 原型:每一个javascript对象(除...
    99+
    2024-04-02
  • 深入了解最常用的JavaScript事件
    目录JavaScript 事件:常用的事件:事件操作总结JavaScript 事件: 事件指的就是当某些组件执行了某些操作后,会触发某些代码的执行。 常用的事件: ...
    99+
    2024-04-02
  • 深入了解zhparser
    瀚高数据库 目录 环境 文档用途 详细信息 环境 系统平台:N/A 版本:14 文档用途 本文参考《zhparser全文检索》,文章ID:051686104;对其进行互补,对zhparser进行进一步...
    99+
    2023-10-27
    postgresql 数据库 php
  • 深入了解JavaScriptPromise
    目录一 什么是 Promise?二 为什么有 Promise?三 Promise常用api四 Promise常用的两个用法总结一 什么是 Promise? 一个 Promise 对...
    99+
    2024-04-02
  • 深入了解Javascript的事件循环机制
    目录单线程的Javascript同步 vs 异步 宏任务 vs 微任务定时器To Be Continued单线程的Javascript JavaScript是一种单线程语言,它主要用...
    99+
    2024-04-02
  • 深入了解JavaScript中的函数柯里化
    目录一、参数复用二、延迟执行三、部分应用四、函数组合JavaScript函数柯里化是一种将接受多个参数的函数转换为一系列接受单个参数的函数的技术。这种技术可以让我们更方便地创建可复用...
    99+
    2023-05-16
    JavaScript函数柯里化 JavaScript 柯里化
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作