css为什么放head里面?有什么优点?
Admin 2021-10-15 群英技术资讯 1058 次浏览
css为什么放head里面?相信不少朋友对于这个问题会比较好奇,css不能和JavaScript一样写在body标签尾部吗?对此本文就与大家一起探讨一下css放body标签尾部会怎么样?以及css放head里面有什么优点?
在这里先说chrome
控制台的一个小技巧:
限制download
速度对我们的测试很有帮助! 可以让我们看清一些细节
我们先把download
速度限制为40kb/s, 开始测试:
当css
引入位置放于body
标签尾部
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <h1>Hello world</h1> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.1.1/css/bootstrap.min.css"> </body> </html>
在浏览器中查看效果:
当bootstrap.min.css
文件未加载完成时, 网页中已经出现了"Hello world", 但样式为默认样式, 说明网页已经渲染过一遍了
当bootstrap.min.css
文件加载完成之后, 网页中的"Hello world"样式发生改变, font-size发生明显变化, 因此可以判断: 网页出现reflow
当css引入位置放于head标签中时:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.1.1/css/bootstrap.min.css"> </head> <body> <h1>Hello world</h1> </body> </html>
在浏览器中打开查看效果:
当bootstrap.min.css
未加载完成时, 网页中并未出现任何内容, 说明此时网页并未发生渲染
当bootstarp.min.css
加载完成后, 网页中出现带有bootstrap
样式的"Hello world", 说明此时网页发生渲染
从上面两个例子可以看出:
css放在body标签尾部时, DOMTree
构建完成之后便开始构建RenderTree
, 并计算布局渲染网页, 等加载解析完css之后, 开始构建CSSOMTree
, 并和DOMTree
重新构建RenderTree
, 重新计算布局渲染网页
css放在head
标签中时, 先加载css, 之后解析css构建CSSOMTree
, 于此同时构建DOMTree
, CSSOMTree
和DOMTree
都构建完毕之后开始构建RenderTree
, 计算布局渲染网页
对比两者, css
放在head
标签中比css
放在body
标签尾部少了一次构建RenderTree
, 一次计算布局和一次渲染网页, 因此性能会更好; 并且css放在body标签尾部时会在网页中短暂出现"裸奔"的HTML, 这不利于用户体验
再讲一个小技巧:
现在大家对于“css为什么放head里面不放body标签尾部”应该都清楚了吧,希望大家阅读完这篇文章能有所收获,想要了解更多CSS的内容,大家可以关注群英网络其它相关文章。
文本转载自脚本之家
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文章就单独讲一下关于css教程div横向居中写法的用法,并且在ie,ie7,firefox兼容问题。横向居中(centering)这是一个简单的技巧,但是值得再说一遍,因为我看见太多的新手问题都是问这个:css如何横向居中?您需要定义元素的宽,并且定义横向的margin,假如您的布局包含在一个层(容器)中,您可以这样定义使它横向居中:#wra ...
父元素: 直接包含其他元素,这个元素就是包含元素的父元素。祖先元素:包含其他元素,这个元素就是包含元素的祖先元素。子元素: 直接被包含的元素。后代元素: 被包含的元素。
在平常的样式排版中,我们经常遇到将某个模块隐藏的场景,通过css隐藏元素的方法有很多种,它们看起来实现的效果是一致的,但实际上每一种方法都有一丝轻微的不同,这些不同决定了在一些特定场合下使用哪一种方法。
这篇文章主要介绍了浅析CSS里的BFC和IFC的用法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
本文通过实例代码给大家介绍了HTML table表格边框的实现思路,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008