我的问题 1. 这些方法中的任何一种是专业的网页设计师所偏爱的吗? 2. 绘制网站时,Web浏览器是否会首选这些方法? 3. 这仅仅是个人喜好吗? 4. 我还缺少其他技巧吗? 5. 注意:以上问题与设计多列布局有关
我的想法: 我确定我会遗漏大量东西,例如某些会破坏布局的异常,但display:table-cell;似乎效果最好,而且我想我会float:left;像以前那样一头雾水地开始替换clear:both;。我已经在网络上阅读了许多有关此的文章和博客,但没有一个给我明确的答案,我应该在布置网站时使用什么。
在您询问的选项中:
float:left; 我不喜欢浮动元素,因为需要附加标记来清除浮动元素。就我而言,整个float概念在CSS规范中设计得很差。不过,我们现在无能为力。但是重要的是它确实可以工作,并且可以在所有浏览器(甚至是IE6 / 7)中工作,因此请根据需要使用它。 如果使用:after选择器清除浮点数,则可能不需要附加的清除标记,但是如果要支持IE6或IE7,则不是可选的。
float:left;
display:inline; 除了IE6 / 7之外,不应将其用于布局,在IE6 / 7中,这display:inline; zoom:1是对的不完整支持的后备hack inline-block。
display:inline;
display:inline; zoom:1
hack inline-block
display:inline-block; 这是我最喜欢的选项。它在所有浏览器中均能很好且始终如一地运行,并警告IE6 / 7,它支持某些元素。但是请参阅上面的针对此问题的解决方案。
display:inline-block;
另一个需要注意的inline-block是,由于内联方面,元素之间的空白与文本单词之间的空白被视为相同,因此您可以在元素之间出现空白。有一些解决方法,但是都不是理想的选择。(最好只是在元素之间不留任何空格)
inline-block
display:table-cell;
table-cell
tableand table-row;
您可能错过了其他技术吗?是。
由于您说的是多列布局,因此您可能需要了解CSS列功能。但是,它并不是最受支持的功能(即使IE9也不受IE支持,并且所有其他浏览器都需要供应商前缀),因此您可能不想使用它。但这是另一种选择,您确实问过。
还有CSS FlexBox功能,该功能旨在让您使文本在框之间流动。这是一项令人兴奋的功能,它允许一些复杂的布局,但这仍处于开发阶段-参见