关于Script放在html中的位置是否影响页面加载
来源:互联网 发布:office for mac下架了? 编辑:程序博客网 时间:2024/05/21 11:12
原地址:https://segmentfault.com/a/1190000004292479
浏览器的渲染过程
Create/Update DOM And request css/image/js:浏览器请求到HTML代码后,在生成DOM的最开始阶段(应该是 Bytes → characters 后),并行发起css、图片、js的请求,无论他们是否在HEAD里。
注意:发起 js 文件的下载 request 并不需要 DOM 处理到那个 script 节点,比如:简单的正则匹配就能做到这一点,虽然实际上并不一定是通过正则:)。这是很多人在理解渲染机制的时候存在的误区。Create/Update Render CSSOM:CSS文件下载完成,开始构建CSSOM
Create/Update Render Tree:所有CSS文件下载完成,CSSOM构建结束后,和 DOM 一起生成 Render Tree。
Layout:有了Render Tree,浏览器已经能知道网页中有哪些节点、各个节点的CSS定义以及他们的从属关系。下一步操作称之为Layout,顾名思义就是计算出每个节点在屏幕中的位置。
Painting:Layout后,浏览器已经知道了哪些节点要显示(which nodes are visible)、每个节点的CSS属性是什么(their computed styles)、每个节点在屏幕中的位置是哪里(geometry)。就进入了最后一步:Painting,按照算出来的规则,通过显卡,把内容画到屏幕上。
以上五个步骤前3个步骤之所有使用 “Create/Update” 是因为DOM、CSSOM、Render Tree都可能在第一次Painting后又被更新多次,比如JS修改了DOM或者CSS属性。
Layout 和 Painting 也会被重复执行,除了DOM、CSSOM更新的原因外,图片下载完成后也需要调用Layout 和 Painting来更新网页。
如果script标签的位置不在首屏范围内,不影响首屏时间
所有的script标签应该放在body底部是很有道理的
但从性能最优的角度考虑,即使在body底部的script标签也会拖慢首屏出来的速度,因为浏览器在最一开始就会请求它对应的js文件,而这,占用了有限的TCP链接数、带宽甚至运行它所需要的CPU。这也是为什么script标签会有async或defer属性的原因之一。
- 关于Script放在html中的位置是否影响页面加载
- 关于<Script>标签在html页面放置位置
- 关于<Script>标签在html页面放置位置
- 关于<Script>标签在html页面放置位置
- HTML页面元素加载顺序----Script标签在Firefox下对背景图片的影响
- <script>标签在html中的位置
- script标签在html中的位置
- <script>标签在HTML中的位置
- script在Html中的摆放位置
- script在html中的摆放位置
- 关于js文件在html页面中放的位置举例说明
- 浅谈JavaScript在Html页面中的位置
- script放在HTML哪里比较好?
- JS中script标签位置对页面的影响
- javascript放在页面的位置问题
- 放在HTML里的哪一部分JavaScripts会在页面加载时被执行?
- 获取Html元素在页面中的绝对位置及问题
- 获取Html元素在页面中的绝对位置及问题
- 在centos7.0上安装laravel5.4
- Listview控件获取当前行的行号和主键
- 获取Listview当前行值
- plsql 触发器教程-当表1的某条数据更新时,表2的某些数据也自动更新
- GridView 编辑功能实现 Delete 、 Update、Edit、Cancel
- 关于Script放在html中的位置是否影响页面加载
- aspx 页面数据绑定 前台数据绑定
- UpdatePanel AsyncPostBackTrigger PostBackTrigger
- Tachyon与Ignite系统对比
- Angular4 第三章(下)路由守卫
- CSS选择器
- Gradle for Android 翻译--第九章 定制高级构建
- px4分支切换问题
- jQuery选择器