我的问题
专业网页设计师是否喜欢这些方法?
网页浏览器在绘制网站时是否首选这些方法?
这只是个人喜好吗?
我还缺少其他技术吗?
注意:以上问题与设计多列布局有关
float :左;
这是我在创建列布局时经常使用的方法,它似乎工作得很好。父级确实会自行折叠,因此您只需要记住 clear:both;
之后。我刚刚发现的另一个缺点是无法垂直对齐文本。
显示:内联;
这似乎纠正了折叠父级的问题,但增加了空格。
从 html 中删除空格似乎是解决此问题的最简单方法,但如果您对 html 真的很挑剔,则不需要。
显示:内联 block ;
似乎行为与 display:inline;
完全一样。
显示:表格单元格;
完美运行。
我的想法:
我确定我错过了很多东西,比如某些会破坏布局的异常,但是 display:table-cell;
似乎效果最好,我想我会的开始替换 float:left;
,因为我似乎总是搞砸 clear:both;
。我在网上阅读了很多关于这方面的文章和博客,但没有一篇给出明确的答案,告诉我在布局我的网站时应该使用什么。
最佳答案
您询问的选项中:
float:left;
我不喜欢 float ,因为需要有额外的标记来清除 float 。就我而言,整个float
概念在 CSS 规范中设计得很糟糕。不过,我们现在对此无能为力。但重要的是它确实有效,并且适用于所有浏览器(甚至 IE6/7),所以如果您喜欢它,请使用它。
如果您使用 :after
选择器来清除 float ,则可能不需要额外的清除标记,但如果您想支持 IE6 或 IE7,这不是一个选项。
display:inline;
这不应该用于布局,除了 IE6/7,其中display:inline; zoom:1
是对inline-block
的损坏支持的后备黑客。display:inline-block;
这是我最喜欢的选择。它在所有浏览器中都运行良好且始终如一,但需要注意的是 IE6/7,它支持某些元素。但是请参阅上面的 hacky 解决方案来解决这个问题。
inline-block
的另一个重要警告是,由于内联方面,元素之间的空白被视为与文本单词之间的空白相同,因此您可以在元素。有解决方法,但没有一个是理想的。 (最好的就是元素之间不要有任何空格)
display:table-cell;
另一个您会遇到浏览器兼容性问题的问题。较旧的 IE 根本无法使用它。但即使对于其他浏览器,值得注意的是table-cell
被设计用于在样式为table
和table-行
;单独使用table-cell
不是预期的方法,因此您可能会遇到不同的浏览器对其进行不同的处理。
您可能错过的其他技巧?是的。
既然你说这是多列布局,那么有一个CSS Columns feature你可能想知道的。但是,它不是最受支持的功能(即使在 IE9 中,IE 也不支持,并且所有其他浏览器都需要供应商前缀),因此您可能不想使用它。但这是另一种选择,你确实问过了。
还有 CSS FlexBox 功能,旨在让您的文本在一个框之间流动。这是一个令人兴奋的功能,它允许一些复杂的布局,但这仍然在开发中——参见 http://html5please.com/#flexbox
希望对您有所帮助。
关于html - float :left; vs display:inline; vs display:inline-block; vs display:table-cell;,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11805352/