网页制作学习:reflow的问题

2016-02-19 23:52 5 1 收藏

今天图老师小编给大家展示的是网页制作学习:reflow的问题,精心挑选的内容希望大家多多支持、多多分享,喜欢就赶紧get哦!

【 tulaoshi.com - Web开发 】

对理论没兴趣的,可以只看红色标注的结论

mozilla的工程师发表过一篇演讲,提到reflow的问题。概念不难理解

mozilla系列浏览器构建网页的过程:1、读取HTML文档,构建网页文档树就是从body开始到结束,把每个table或者div记录下来 2、reflow通过CSS或者其他因素计算文档树中每个对象的大小、布局等 3、把计算结果显示在屏幕上

简单言之浏览器的运算开销大多在reflow这一步,就是获取对象的布局、排版等样式,如果样式的定义有误则浏览器会重新运算,之后再展现在浏览器上。
另外通过JS来覆写对象的样式是比较典型的一种销毁原样式并重建的过程,这种销毁和重建,都会增加浏览器的开销。其中CSS方面,常用的JS切换display:none和display:block是个最好的例子

而HTML文档中,比较典型的是图片的宽高未定义,浏览器会自行计算,所以很多网页优化的文章都列入了这条,即可能的话,就把图片的宽度高度写进HTML文档里。

从渲染过程上来讲,mozilla有过CSS的书写建议:1.显示样式 display/position/float/clear 2.自身样式 width/height/margin/padding/border/background 3.内容样式 line-height/text-align/font系列(font-size/font-weight)/color/text-decoration/vitical-align

猜测这应该和mozilla系列浏览器本身渲染网页的优先级顺序切合。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

我的书写顺序:

select{clear:both;display:block;float:left;margin:100px;padding:100px;width:100px;height:100px;line-height:100px;text-align:center;color:#000;font-size:12px;font-weight:400;background:#FFF;border:1px solid #F00;)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

大致符合建议规则,同时因为书写样式时修改频率最高的就是背景和边框,所以放在最外面,取了规则和工作效率的平衡点。

来源:https://www.tulaoshi.com/n/20160219/1630780.html

延伸阅读
标签: Web开发
Dreamweaver是一个非常简单易用但又功能强大的网页制作软件。但是,它却又一个令很多初学者很困惑的问题。那就是空格。在Dreamweaver中使用空格远远没有象word中一样方便。比如首行无法空格,句子中间空一格以上都是不行的。原因是什么呢?这是因为在HTML语言中多于一个的空格都被忽略不计。这样就造成了空格困难的原因。 如何很好地解决Dream...
标签: Web开发
如果你是一个CSS的初学者,那么这个教程资源汇总的文章,你有必要收藏起来。 想做网页,但面对复杂的 CSS 怕力不从心?不用担心,你所需要的仅仅是一些耐心,一些练习和一点点时间。不要拘泥于过分复杂的教程,从这 20个循序渐进的教程 开始吧。 开始之前 开始之前,再问自己一下为什么要学习CSS,它可以应用到网页设计的那些方面?下面...
标签: Web开发
你正在学习CSS布局吗?是不是还不能完全掌握纯CSS布局?通常有两种情况阻碍你的学习: 第一种可能是你还没有理解CSS处理页面的原理。在你考虑你的页面整体表现效果前,你应当先考虑内容的语义和结构,然后再针对语义、结构添加CSS。这篇文章将告诉你应该怎样把HTML结构化。 另一种原因是你对那些非常熟悉的表现层属性(例如:cel...
标签: Web开发
经常听到网友苦述自己的网页中有许多图片不能正常显示,究竟为什么不能正常显示呢?总结其原因绝大部分都是因为使用了错误路径所致。网页中的图像、动画等素材都有自己固定的存放位置,网页只是通过路径使用HTML语言来调用它们,然后把它们显示在网页中。在网页中的路径大体可分为相对路径和绝对路径,大家(尤其是初学网页设计的朋友)往往...
一、Margin(框距)padding(边框距) margin属性设置顺序:上右下左 padding属性设置顺序:上右下左 margin:25px 0 25px 0; 简写:margin:25px 0; 二、Display显示属性设置 (1)、Display属性none (隐藏) .alt {display:none;} <span class=”alt”Content List Part</span (2)、Display属性block (块/区域) Img {displ...

经验教程

132

收藏

85
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部