这篇文章主要介绍css要放在head标签中的原因,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
创新互联建站是一家集成都网站制作、成都做网站、网站页面设计、网站优化SEO优化为一体的专业网站制作公司,已为成都等多地近百家企业提供网站建设服务。追求良好的浏览体验,以探求精品塑造与理念升华,设计最适合用户的网站页面。 合作只是第一步,服务才是根本,我们始终坚持讲诚信,负责任的原则,为您进行细心、贴心、认真的服务,与众多客户在蓬勃发展的市场环境中,互促共生。
思考: css
为什么要放在head
标签中, 而不能像javascript
一样置于body
标签尾部?
Talk is cheap, show me the code.
OK, 那我们通过写一些代码来得出结果
在这里先说chrome
控制台的一个小技巧:
限制download
速度对我们的测试很有帮助! 可以让我们看清一些细节
我们先把download
速度限制为40kb/s, 开始测试:
当css
引入位置放于body
标签尾部
Document Hello world
在浏览器中查看效果:
当bootstrap.min.css
文件未加载完成时, 网页中已经出现了"Hello world", 但样式为默认样式, 说明网页已经渲染过一遍了
当bootstrap.min.css
文件加载完成之后, 网页中的"Hello world"样式发生改变, font-size发生明显变化, 因此可以判断: 网页出现reflow
当css引入位置放于head标签中时:
Document Hello world
在浏览器中打开查看效果:
当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中有什么优点?"这个疑惑也是极好~
以上是“css要放在head标签中的原因”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!