这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助

HTML页面加载过程会发生什么?因为浏览器网络拉取资源是多线程的,但是dom树的操作都是在一个线程中的,所以网页资源的解析、js加载、dom树渲染都是一个线程执行,所以就会线程任务就会相互抢占,先来先执行。而当浏览器加载html文件时,会自上而下加载。我们先看一下下面的例子:
<!DOCTYPE html>
<html lang="en">
<head>
<title>Document</title>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.4.1/dist/css/bootstrap.min.css">
<style>
#app {
width: 100px;
height: 100px;
background-color: red;
}
</style> <script>
alert('代码的script');
</script>
// alert('src的script');
<script src="./test.js"></script>
</head>
<body>
<div id="app"></div>
</body>
</html>
由于html文件的加载自上而下的,所以不管传入的脚本script是代码还是链接,都是先写先加载,可能我们会问问什么style没有加载,不是没有加载,而是已经解析并加载了,因为对css进行解析会生成cssom规则树,然后需要结合DOM树构建渲染树,而我们的dom元素是命名在body标签中定义,由于当前解析的是head标签,这阶段还没有渲染dom,所以一般在html中操作dom的时机都是在body中的。

在上面例子,我们有没有发现在解析html文档过程中,但执行script脚本之前是不是有一段时间在加载,其实是在加载link资源,也就是css资源,等css资源执行完毕后才会执行后面script,这就是CSS阻塞,这里阻塞了其后面的js语句的执行

而style标签引入的样式是不会阻塞浏览器渲染也不会阻塞DOM解析,但是可能会出现闪屏现象(使用transition动画时)。 上面只是在head标签中引入样式,如果是在body标签中引入样式,css是否也会阻塞?

  • 在link引入前后定义DOM元素:css加载会阻塞后面DOM元素的渲染,以及前面元素的css样式渲染。

<body>
<button class="btn btn-primary">test1</button>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.4.1/dist/css/bootstrap.min.css">
<div>test2</div>
</body>

  • 在link引入前后引入脚本:在link引入样式前执行脚本,在link引入样式后执行版本,我们会发现link会阻塞后面脚本的执行,需要等css资源加载完毕才会执行。

我们都知道在html中加载资源除了css,还有js资源加载,既然看了有CSS资源加载阻塞,是不是也有js阻塞?是的,script引入与使用分为两种方式:head中引入body中引入

  • 在head标签中引入script:如果是head中引入脚本是不能直接操作DOM渲染,因为DOM还没有加载与渲染。那么有办法可以解决吗?其实是有的,使用defer(延迟执行,等DOM解析完成再执行JS脚本)和async(异步执行,保证DOM树和JS脚本并行执行)。

<head>
<script src="./a.js" defer></script>
<script src="./a.js" async></script>
</head>
 
  • 在body标签中引入script: 当引入的script脚本后下载并解析完成后,才去加载后面DOM元素,但是script脚本不会影响脚本执行前的DOM元素渲染。所以一般把所有脚本都会丢到</body>前。
<body>
<script src="https://code.jquery.com/jquery-3.4.1.js"></script>
<div>test</div>
</body>

所以一般是把引入式(链接)放在head标签内,内联式一般是放在body内。

本文转载于:

https://juejin.cn/post/7199994978977120316

如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

记录--什么时候会阻塞HTML文档渲染过程?的更多相关文章

  1. 利用Gulp实现JSDoc 3的文档编写过程中的实时解析和效果预览

    ### 利用Gulp实现JSDoc 3的文档编写过程中的实时解析和效果预览 http://segmentfault.com/a/1190000002583569

  2. 制作Aspose CHM文档的过程记录

    欢迎和大家交流技术相关问题: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://g ...

  3. 自记录:git如何上传文档到git@osc

    前提: D盘有gitserver文件夹 双击桌面的git.exe文件,打开git命令窗口 输入cd  d: 命令进入D盘 输入cd gitserver命令进入 找到git@osc自己参与项目里的htt ...

  4. Java在DOS命令下的运行及其API文档制作过程

    该文档主要描述java程序在DOS命令下的运行,以及一些常用的命令 常用DOS命令: d: 回车 盘符切换 dir(directory):列出当前目录下的文件以及文件夹 md (make direct ...

  5. mfc创建文档视图过程

    一.如何创建文档视图界面: 创建新的文档视图界面,只需要调用CDocTemplate::OpenDocumentFile(strpath)即可.(strpath为要打开的文档路径,如果是NULL,则生 ...

  6. 详细描述一下 Elasticsearch 索引文档的过程 ?

    面试官:想了解 ES 的底层原理,不再只关注业务层面了. 解答: 这里的索引文档应该理解为文档写入 ES,创建索引的过程. 文档写入包含:单文档写入和批量 bulk 写入,这里只解释一下:单文档写入流 ...

  7. 详细描述一下 Elasticsearch 索引文档的过程 ?

    这里的索引文档应该理解为文档写入 ES,创建索引的过程. 文档写入包含:单文档写入和批量 bulk 写入,这里只解释一下:单文档写入流程. 记住官方文档中的这个图. 第一步:客户写集群某节点写入数据, ...

  8. 详细描述一下 Elasticsearch 索引文档的过程?

    协调节点默认使用文档 ID 参与计算(也支持通过 routing),以便为路由提供合适的分片. shard = hash(document_id) % (num_of_primary_shards) ...

  9. 详细描述一下 Elasticsearch 更新和删除文档的过程?

    1.删除和更新也都是写操作,但是 Elasticsearch 中的文档是不可变的,因此不 能被删除或者改动以展示其变更: 2.磁盘上的每个段都有一个相应的.del 文件.当删除请求发送后,文档并没有真 ...

  10. 使用Xcode HeaderDoc和Doxygen文档化你的Objective-C和Swift代码

    在一个应用的整个开发过程中涉及到了无数的步骤.其中一些是应用的说明,图片的创作,应用的实现,和实现过后的测试阶段.写代码可能组成了这个过程的绝大部分,因为正是它给了应用生命,但是这样还不够,与它同等重 ...

随机推荐

  1. JS leetcode 加一 题解分析

    壹 ❀ 引 今天是刷leetcode的第三天,根据推荐优先刷数据结构相关的卡片,先把数据结构知识体系建立起来,不然就是题目无从下手答案也看不懂的尴尬局面.那么今天的题目是加一,老规矩,先记录自己的解题 ...

  2. NC26212 小石的签到题

    题目链接 题目 题目描述 小石和小阳玩游戏,一共有 \(n\) 个数,分别为 \(1 \sim n\) .两人轮流取数,小石先手.对于每轮取数,都必须选择剩下数中的任意一个数 \(x\) ,同时还要取 ...

  3. NC19429 红球进黑洞

    题目链接 题目 题目描述 在心理疏导室中有一种奇特的疏导工具,叫做红球.红球被提前分为了许多正方形小方格. 每当有人来找ATB做心理疏导时,ATB就会让他去先玩红球,然后通过红球小格方的高度来判断一个 ...

  4. Python 装饰器解析(二)

    前面一篇文章介绍了python装饰器,最后引入了functools.wraps的使用,本篇文章将对它进行深入的探究. functools模块提供了一系列的高阶函数以及对可调用对象的操作,其中为人熟知的 ...

  5. .NET周刊【2月第2期 2024-02-11】

    国内文章 C#/.NET该如何自学入门? https://www.cnblogs.com/Can-daydayup/p/18006914 随着DotNetGuide技术社区交流群的扩大,很多新成员希望 ...

  6. Python递归遍历目录并删除文件中的前N行

    1 import os 2 3 # 遍历目录下的所有文件 4 def check_file(file_path): 5 os.chdir(file_path) 6 print(os.path.absp ...

  7. The Network Adapter could not establish the connection errorCode 17002, state 08006

    问题说明 今天在centos7虚拟机中运行java程序,程序启动需要连接主机的oracle,报错: The Network Adapter could not establish the connec ...

  8. 【Android 逆向】r0zapataNative.apk 破解

    1. apk 安装到手机,需要输入内容,随便输入,提示fail... 2. apk 导入到jadx中查看一下 MainActivity.java String textData = "b2F ...

  9. 异常处理try...except...finally---day26

    1.认识异常处理 # ### 认识异常处理 #IndexError 索引超出序列范围 #lst = [1,2,3,4] #print(lst[10]) #KeyError 字典中查找一个不存在的关键字 ...

  10. ChainMap合并字典

    在python中,我们有两个字典需要合并的时候,可以使用字典的update方法 a = {'a': 1, 'b': 2} b = {'x': 3, 'y': 4} a.update(b) print( ...