gpt4 book ai didi

html - float :left; vs display:inline; vs display:inline-block; vs display:table-cell;

转载 作者:行者123 更新时间:2023-11-28 09:57:13 31 4
gpt4 key购买 nike

我的问题

  1. 这些方法中有哪一种是专业网页设计师所偏爱的吗?

  2. Web 浏览器在绘制网站时是否首选这些方法中的任何一种?

  3. 这只是个人喜好吗?

  4. 我还缺少其他技巧吗?

注意:以上问题是关于设计多列布局


float :左;

http://jsfiddle.net/CDe6a/

float:left image

这是我在创建列布局时经常使用的方法,而且看起来效果很好。不过,父级确实会自行崩溃,因此您只需要记住之后 clear:both; 即可。我刚刚发现的另一个缺点是无法垂直对齐文本。

显示:内联;

这似乎解决了折叠父级的问题,但添加了空格。

http://jsfiddle.net/CDe6a/1/

display:inline image

从 html 中删除空格似乎是解决此问题最简单的方法,但如果您对 html 真的很挑剔,则不需要这样做。

http://jsfiddle.net/CDe6a/2/

no html whitespace image

显示:内联 block ;

似乎与 display:inline; 完全一样。

http://jsfiddle.net/CDe6a/3/

display:inline-block image

显示:表格单元格;

http://jsfiddle.net/CDe6a/4/

display:table-cell image

完美运行。

我的想法:

我确定我遗漏了很多东西,比如某些会破坏布局的异常,但是 display:table-cell; 似乎效果最好,我想我会的开始替换 float:left;,因为我似乎总是在 clear:both; 上搞砸。我在网络上阅读了很多关于此的文章和博客,但没有一篇明确回答我在布局我的网站时应该使用什么。

最佳答案

您询问的选项中:

  • float:left;
    我不喜欢 float ,因为需要额外的标记来清除 float 。就我而言,整个 float 概念在 CSS 规范中设计得很糟糕。不过,我们现在对此无能为力。但重要的是它确实有效,而且适用于所有浏览器(甚至 IE6/7),所以如果你喜欢就使用它吧。

如果您使用 :after 选择器来清除 float ,则可能不需要额外的清除标记,但如果您想支持 IE6 或 IE7,则这不是一个选项。

  • 显示:内联;
    这不应该用于布局,IE6/7 除外,其中 display:inline; zoom:1 是对 inline-block 损坏支持的后备 hack。

  • display:inline-block;
    这是我最喜欢的选择。它在所有浏览器上都运行良好且一致,但需要注意的是 IE6/7,它支持某些元素。但是请参阅上面的 hacky 解决方案来解决这个问题。

inline-block 的另一个重要警告是,由于内联方面,元素之间的空白被视为与文本单词之间的空白相同,因此您可以在之间出现空白元素。有一些解决方法,但没有一个是理想的。 (最好的是元素之间不要有任何空格)

  • 显示:表格单元格;
    另一个浏览器兼容性问题。较旧的 IE 根本无法使用此功能。但即使对于其他浏览器,值得注意的是 table-cell 被设计用于在样式为 tabletable- 的元素内部的上下文中行;单独使用 table-cell 不是预期的方法,因此您可能会遇到不同的浏览器以不同方式处理它。

您可能错过的其他技巧?是的。

  • 既然你说这是一个多列布局,那么有一个 CSS Columns feature你可能想知道的。然而,它并不是最受支持的功能(IE 即使在 IE9 中也不支持,并且所有其他浏览器都需要供应商前缀),因此您可能不想使用它。但这是另一种选择,你确实问过。

  • 还有 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/24867828/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com