当前位置: 首页 > article >正文

破解浏览器渲染“死锁”:CSS与JS如何影响页面加载速度?

破解浏览器渲染“死锁”:CSS与JS如何影响页面加载速度?

在这个快速发展的Web世界里,性能是开发者们永恒的追求。当你打开一个网页,可能会注意到一些页面加载特别慢,甚至产生短暂的“白屏”,你有没有想过,CSS和JS如何在这个过程中起到了关键作用

今天,我们要揭秘浏览器渲染流程中的一个关键问题:CSS和JS的加载与执行是否会阻塞渲染?

准备好了吗?跟着我一起,从浏览器如何渲染页面开始,逐步深入探索这背后的渲染逻辑,看看如何通过合适的优化让页面加载速度更快,用户体验更好!

从浏览器渲染过程讲起:渲染的“迷宫”

首先,我们得了解浏览器是如何渲染一个网页的。浏览器渲染过程不是一蹴而就的,它是一个复杂的步骤,涉及HTML解析、CSS解析、JavaScript执行,还有如何渲染出屏幕上可见的页面。让我们逐步分析。

1. HTML解析:构建DOM树

当浏览器开始加载HTML文档时,首先会创建一个DOM树。DOM(Document Object Model)是页面结构的抽象表示,浏览器会根据HTML文档中的元素标签来逐步构建DOM树。

2. CSS解析:构建CSSOM树

与DOM树相对应的是CSSOM,它是由CSS样式构成的对象模型。浏览器需要根据页面的样式表解析出每个元素的样式,并形成CSSOM树。

3. 渲染树构建

DOM树和CSSOM树的结合会生成渲染树,它包含了页面上所有要显示的可见元素及其样式。此时,浏览器已经知道了页面的结构和样式,准备进行下一步操作——布局和绘制。

4. 布局与绘制

  • 布局:计算每个元素的位置和尺寸。
  • 绘制:按照之前计算出的布局,最终把元素显示到屏幕上。

5. 合成与呈现

最后,浏览器会将页面分为多个图层进行合成,然后将所有的图层绘制到屏幕上,最终展现给用户。


CSS和JS的角色:渲染的关键玩家

在这个渲染过程中,CSSJS在浏览器的加载、解析和执行中扮演了至关重要的角色。它们能让页面更加美观、互动,但在不恰当的时机加载时,也会阻塞渲染,导致页面的显示速度变慢。我们接下来深入看一下这两者的影响。

CSS的阻塞性:加载时的瓶颈

CSS阻塞渲染:
  1. 阻塞DOM树构建:
    CSS影响页面的显示,它告诉浏览器每个元素应该如何展示。如果CSS文件在HTML内容加载后才被请求,浏览器就必须等到CSS加载完成后才能构建完整的渲染树,造成阻塞。
  2. 未加载CSS时的页面闪烁:
    当CSS加载缓慢时,浏览器无法立即应用样式,会先显示一个没有样式的页面结构,导致“页面闪烁”现象。这个过程会被称为FOUC(Flash of Unstyled Content)。
解决方案:
  1. 使用<link rel="preload">提前加载CSS:

    通过rel="preload"提前加载CSS文件,浏览器就能在开始渲染HTML时就开始请求CSS,避免渲染过程的阻塞。

<link rel="preload" href="styles.css" as="style">
  1. 内联CSS:

    对于一些关键样式,直接内联到HTML中,可以让它们立即生效,无需等待外部CSS文件加载。

<style>body {background-color: #fff;}
</style>

JS的阻塞性:浏览器的“中断”

JS阻塞渲染:

JavaScript的加载和执行可能会影响渲染流程。当浏览器遇到<script>标签时,它会停止HTML的解析和DOM树的构建,直到JS执行完毕才会继续。这就是为什么很多JS加载较慢的页面会出现渲染延迟。

JS和布局的关系:
  1. 修改DOM和CSSOM:
    JS可以修改DOM元素的结构,也可以修改CSS样式。如果JS在渲染树构建之前执行,它会强制浏览器重新计算布局,浪费不必要的资源。
  2. 脚本的执行顺序问题:
    如果JS是同步加载的,浏览器会被强制停止渲染,直到它加载并执行完。这样一来,页面的渲染进度就被“打断”了。
解决方案:
  1. 使用asyncdefer

    • async:让JS文件在后台加载,不阻塞HTML的解析,加载完成后立即执行。
    • defer:让JS文件等到HTML解析完毕后再执行,这样不会打断渲染。
<script src="script.js" async></script>
<script src="script.js" defer></script>
  1. 将JS放到</body>标签之后:

    如果你不使用asyncdefer,可以考虑将JS文件放在页面底部,这样可以确保浏览器先渲染HTML和CSS,最后再执行JS。

<body><script src="script.js"></script>
</body>

总结:让浏览器渲染更快的优化策略

浏览器的渲染是一个精细的过程,每个环节的阻塞都可能导致页面加载的延迟。为了提高页面的加载速度并优化用户体验,CSS和JS的加载顺序与方式至关重要。

  • 提前加载CSS,避免渲染阻塞。
  • 异步加载JS,避免打断页面渲染。
  • 优化文件大小与请求次数,减少不必要的阻塞。

通过这些优化,你的页面将变得更加流畅,告别加载慢,迎接快速渲染,从而提升用户体验。

相关文章:

破解浏览器渲染“死锁”:CSS与JS如何影响页面加载速度?

破解浏览器渲染“死锁”&#xff1a;CSS与JS如何影响页面加载速度&#xff1f; 在这个快速发展的Web世界里&#xff0c;性能是开发者们永恒的追求。当你打开一个网页&#xff0c;可能会注意到一些页面加载特别慢&#xff0c;甚至产生短暂的“白屏”&#xff0c;你有没有想过&a…...

操作系统(Linux Kernel 0.11Linux Kernel 0.12)解读整理——内核初始化(main init)之内存的划分

前言 MMU&#xff1a;内存管理单元(Memory Management Unit)完成的工作就是虚拟地址到物理地址的转换&#xff0c;可以让系统中的多个程序跑在自己独立的虚拟地址空间中&#xff0c;相互不会影响。程序可以对底层的物理内存一无所知&#xff0c;物理地址可以是不连续的&#x…...

.NET MAUI进行UDP通信(二)

上篇文章有写过一个简单的demo&#xff0c;本次对项目进行进一步的扩展&#xff0c;添加tabbar功能。 1.修改AppShell.xaml文件&#xff0c;如下所示&#xff1a; <?xml version"1.0" encoding"UTF-8" ?> <Shellx:Class"mauiDemo.AppShel…...

社区养老服务平台的设计与实现(代码+数据库+LW)

摘 要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对信息管理混乱&#xff0c;出错率高&#xff0c;信息安全性差&#…...

生信软件管家——conda vs pip

pip vs conda&#xff1a; 安装过python包的人自然两种管理软件都用过&#xff0c; Pip install和Conda install在Python环境中用于安装第三方库和软件包&#xff0c;但它们在多个方面存在显著的区别 总的来说&#xff1a; pip是包管理软件&#xff0c;conda既是包管理软件&…...

项目文章 | PNAS 斑马鱼转录因子ChIP-seq助力解析GATA6突变相关的肝脏疾病机制

近日&#xff0c;西南大学阮华/黄红辉团队联合重庆大学邱菊辉/王贵学团队在PNAS发表了题为“An animal model recapitulates human hepatic diseases associated with GATA6 mutations”的研究论文。该研究构建了一个gata6敲除斑马鱼模型&#xff0c;它重现了gata6突变患者的大…...

JavaScript系列(44)--微服务架构实现详解

JavaScript微服务架构实现详解 &#x1f3d7;️ 今天&#xff0c;让我们来学习如何在JavaScript中实现微服务架构。微服务架构是一种将应用程序构建为一组小型服务的方法&#xff0c;每个服务运行在自己的进程中&#xff0c;并通过轻量级机制通信。 微服务基础概念 &#x1f…...

Vue组件开发-使用 html2canvas 和 jspdf 库实现PDF文件导出 设置页面大小及方向

在 Vue 项目中实现导出 PDF 文件、调整文件页面大小和页面方向的功能&#xff0c;使用 html2canvas 将 HTML 内容转换为图片&#xff0c;再使用 jspdf 把图片添加到 PDF 文件中。以下是详细的实现步骤和代码示例&#xff1a; 步骤 1&#xff1a;安装依赖 首先&#xff0c;在项…...

Java-并发编程-特性-可见性-synchronized如何保证可见性?

synchronized 能保证可见性吗&#xff1f; 在Java并发编程中&#xff0c;synchronized 关键字不仅用于实现互斥访问&#xff0c;还能够保证内存可见性。理解这一点需要了解Java内存模型&#xff08;Java Memory Model&#xff0c;JMM&#xff09;以及happens-before&#xff0…...

iOS 权限管理:同时请求相机和麦克风权限的最佳实践

引言 在开发视频类应用时&#xff0c;我们常常会遇到需要同时请求相机和麦克风权限的场景。比如&#xff0c;在用户发布视频动态时&#xff0c;相机用于捕捉画面&#xff0c;麦克风用于录制声音&#xff1b;又或者在直播功能中&#xff0c;只有获得这两项权限&#xff0c;用户…...

【深入理解FFMPEG】命令行阅读笔记

这里写自定义目录标题 第三章 FFmpeg工具使用基础3.1 ffmpeg常用命令3.1.13.1.3 转码流程 3.2 ffprobe 常用命令3.2.1 ffprobe常用参数3.2.2 ffprobe 使用示例 3.3 ffplay常用命令3.3.1 ffplay常用参数3.3.2 ffplay高级参数3.3.4 ffplay快捷键 第4章 封装与解封装4.1 视频文件转…...

数据结构:二叉树—面试题(二)

1、二叉树的最近公共祖先 习题链接https://leetcode.cn/problems/lowest-common-ancestor-of-a-binary-tree/description/ 描述&#xff1a; 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个节点…...

【C++高并发服务器WebServer】-6:信号

本文目录 信号的概念1.1 core文件1.2 kill命令1.3 alarm函数1.4 setitimer调用1.5 signal捕捉信号1.6 信号集1.7 内核实现信号捕捉的过程1.8 sigaction1.9 sigchld 信号的概念 信号是 Linux 进程间通信的最古老的方式之一&#xff0c;是事件发生时对进程的通知机制&#xff0c…...

《探秘人工智能:从基础到未来变革》

在当今科技飞速发展的时代&#xff0c;人工智能&#xff08;AI&#xff09;无疑是最具影响力和变革性的技术之一。从手机里智能语音助手到自动驾驶汽车&#xff0c;从智能医疗诊断到智能金融服务&#xff0c;人工智能已经渗透到我们生活和工作的方方面面&#xff0c;悄然改变着…...

【数据分享】1929-2024年全球站点的逐月平均能见度(Shp\Excel\免费获取)

气象数据是在各项研究中都经常使用的数据&#xff0c;气象指标包括气温、风速、降水、湿度等指标&#xff01;说到气象数据&#xff0c;最详细的气象数据是具体到气象监测站点的数据&#xff01; 有关气象指标的监测站点数据&#xff0c;之前我们分享过1929-2024年全球气象站点…...

【PyTorch】3.张量类型转换

个人主页&#xff1a;Icomi 在深度学习蓬勃发展的当下&#xff0c;PyTorch 是不可或缺的工具。它作为强大的深度学习框架&#xff0c;为构建和训练神经网络提供了高效且灵活的平台。神经网络作为人工智能的核心技术&#xff0c;能够处理复杂的数据模式。通过 PyTorch&#xff0…...

不解释快上车

聊一聊 最近有小伙伴问我有小红书图片和短视频下载的软件吗&#xff0c;我心想&#xff0c;下载那上面的图片和视频做什么&#xff1f;也许是自己没有这方面的需求&#xff0c;不了解。 不过话又说回来&#xff0c;有些很多下载器可能作者没有持续的维护&#xff0c;所以可能…...

C++红黑树详解

文章目录 红黑树概念规则为什么最长路径不超过最短路径的二倍&#xff1f;红黑树的时间复杂度红黑树的结构插入叔叔节点情况的讨论只变色(叔叔存在且为红)抽象的情况变色单旋&#xff08;叔叔不存在或叔叔存在且为黑&#xff09;变色双旋&#xff08;叔叔不存在或叔叔存在且为黑…...

csapp2.4节——浮点数

目录 二进制小数 十进制小数转二进制小数 IEEE浮点表示 规格化表示 非规格化表示 特殊值 舍入 浮点运算 二进制小数 类比十进制中的小数&#xff0c;可定义出二进制小数 例如1010.0101 小数点后的权重从-1开始递减。 十进制小数转二进制小数 整数部分使用辗转相除…...

神经网络|(一)加权平均法,感知机和神经元

【1】引言 从这篇文章开始&#xff0c;将记述对神经网络知识的探索。相关文章都是学习过程中的感悟和理解&#xff0c;如有雷同或者南辕北辙的表述&#xff0c;请大家多多包涵。 【2】加权平均法 在数学课本和数理统计课本中&#xff0c;我们总会遇到求一组数据平均值的做法…...

Spring 框架:配置缓存管理器、注解参数与过期时间

在 Spring 框架中&#xff0c;可通过多种方式配置缓存具体行为&#xff0c;常见配置方法如下。 1. 缓存管理器&#xff08;CacheManager&#xff09;配置 基于内存的缓存管理器配置&#xff08;以SimpleCacheManager为例&#xff09; SimpleCacheManager 是 Spring 提供的简单…...

FPGA实现任意角度视频旋转(完结)视频任意角度旋转实现

本文主要介绍如何基于FPGA实现视频的任意角度旋转&#xff0c;关于视频180度实时旋转、90/270度视频无裁剪旋转&#xff0c;请见本专栏前面的文章&#xff0c;旋转效果示意图如下&#xff1a; 为了实时对比旋转效果&#xff0c;采用分屏显示进行处理&#xff0c;左边代表旋转…...

openlayer getLayerById 根据id获取layer图层

背景&#xff1a; 在项目中使用getLayerById获取图层&#xff0c;这个getLayerById()方法不是openlayer官方文档自带的&#xff0c;而是自己封装的一个方法&#xff0c;这个封装的方法的思路是&#xff1a;遍历所有的layer&#xff0c;根据唯一标识【可能是id&#xff0c;也可能…...

【Jave全栈】Java与JavaScript比较

文章目录 前言一、Java1、 历史与背景2、语言特点3、应用场景4、生态系统 二、JavaScript1、历史与背景2、语言特点3、应用场景4、 生态系统 三、相同点四、不同点1、语言类型2、用途3、语法和结构4、性能5、生态系统6、开发模式 前言 Java和JavaScript是两种不同的编程语言&a…...

设计模式-建造者模式、原型模式

目录 建造者模式 定义 类图 优缺点 角色 建造者模式和工厂模式比较 使用案例 原型模式 定义 类图 优缺点 应用场景 应用类型 浅克隆 深克隆 建造者模式 定义 将一个复杂的对象的构造与它的表示分离&#xff0c;使同样的构建过程可以创建不同的表示&#xff0c;…...

PTMD2.0-疾病相关的翻译后修饰数据库

翻译后修饰&#xff08;PTMs&#xff0c;post-translational modifications&#xff09;通过调节蛋白质功能参与了几乎所有的生物学过程&#xff0c;而 PTMs 的异常状态常常与人类疾病相关。在此&#xff0c;PTMD 2.0展示与疾病相关的 PTMs 综合数据库&#xff0c;其中包含 93 …...

【Git版本控制器--3】Git的远程操作

目录 理解分布式版本控制系统 创建远程仓库 仓库被创建后的配置信息 克隆远程仓库 https克隆仓库 ssh克隆仓库 向远程仓库推送 拉取远程仓库 忽略特殊文件 为什么要忽略特殊文件&#xff1f; 如何配置忽略特殊文件&#xff1f; 配置命令别名 标签管理 理…...

批量创建ES索引

7.x from elasticsearch import Elasticsearch# 配置 Elasticsearch 连接 # 替换为你的 Elasticsearch 地址、端口、用户名和密码 es Elasticsearch([http://10.10.x.x:43885],basic_auth(admin, XN272G9THEAPYD5N5QORX3PB1TSQELLB) )# # 测试连接 # try: # # 尝试获取集…...

模块初阶学习

当我们在过去想要实现一个功能时&#xff0c;例如Swap交换函数时&#xff0c;我们需要不断考虑参数的正确与否。如果是在c语言&#xff0c;我们还需要不断更改函数名字&#xff0c;以防止函数名重复。在c我们可以通过函数名重载解决这个问题&#xff0c;但还是有一些小问题&…...

rust学习-rust中的保留字

rust学习-rust中的保留字 已使用的保留字未来可能使用的保留字 保留字是语言中预定义的标识符&#xff0c;不能用作变量名、函数名或其他自定义标识符&#xff0c;Rust的保留字大致可以分为两类&#xff1a;已使用的保留字和未来可能使用的保留字 已使用的保留字 as&#xff1…...