当前位置: 首页 > 面试题库 >

向左飘浮; vs display:inline; vs display:inline-block; vs display:table-cell;

云航
2023-03-14
问题内容

我的问题
1. 这些方法中的任何一种是专业的网页设计师所偏爱的吗?
2. 绘制网站时,Web浏览器是否会首选这些方法?
3. 这仅仅是个人喜好吗?
4. 我还缺少其他技巧吗?
5. 注意:以上问题与设计多列布局有关

我的想法:
我确定我会遗漏大量东西,例如某些会破坏布局的异常,但display:table-cell;似乎效果最好,而且我想我会float:left;像以前那样一头雾水地开始替换clear:both;。我已经在网络上阅读了许多有关此的文章和博客,但没有一个给我明确的答案,我应该在布置网站时使用什么。


问题答案:

在您询问的选项中:

  • float:left;
    我不喜欢浮动元素,因为需要附加标记来清除浮动元素。就我而言,整个float概念在CSS规范中设计得很差。不过,我们现在无能为力。但是重要的是它确实可以工作,并且可以在所有浏览器(甚至是IE6 / 7)中工作,因此请根据需要使用它。
    如果使用:after选择器清除浮点数,则可能不需要附加的清除标记,但是如果要支持IE6或IE7,则不是可选的。

  • display:inline;
    除了IE6 / 7之外,不应将其用于布局,在IE6 / 7中,这display:inline; zoom:1是对的不完整支持的后备hack inline-block

  • display:inline-block;
    这是我最喜欢的选项。它在所有浏览器中均能很好且始终如一地运行,并警告IE6 / 7,它支持某些元素。但是请参阅上面的针对此问题的解决方案。

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

  • display:table-cell;
    另一个浏览器兼容性问题。较旧的IE根本无法使用。但是,即使对于其他浏览器,也值得注意的是,该table-cell设计用于在样式为tableand table-row;的元素内部的上下文中使用。table-cell隔离使用并不是实现此目的的预期方法,因此您可能会遇到不同的浏览器将其区别对待的情况。

您可能错过了其他技术吗?是。

  • 由于您说的是多列布局,因此您可能需要了解CSS列功能。但是,它并不是最受支持的功能(即使IE9也不受IE支持,并且所有其他浏览器都需要供应商前缀),因此您可能不想使用它。但这是另一种选择,您确实问过。

  • 还有CSS FlexBox功能,该功能旨在让您使文本在框之间流动。这是一项令人兴奋的功能,它允许一些复杂的布局,但这仍处于开发阶段-参见



 类似资料:
  • 问题内容: 我有一个页面,其中页眉由三个div组成-一个浮动在左侧,一个浮动在右侧,以及一个在它们之间。我希望该中心div居中,但遗憾的是不存在,我不能只是将其浮动到左侧并添加填充,因为它必须根据窗口大小进行更改。 有什么简单的我可以忽略的吗?还是我会怎么做? 更新: 此外,我想找到一种方法将中间div居中于div 之间的空间 中,以防看起来更好。 问题答案: 如果您有两个浮动div,那么您知道边

  • 飘刃 (Piao Ren) Vue 项目前端工程构建工具,使用 Rollup 打包 特点优势 源码少,除去第三方工具,飘刃所有核心代码共8个文件不到1000行,看源码不头疼 速度快,开发过程中无需 babel 转译,飘刃只转 import/export ,其余直接输出到浏览器 效率高,使用谷歌浏览器 99.9% 源码调试,无需 source map ,告别组件 this 乱指 window 够直观

  • 首先,请耐心等待,因为我英语说得不太好,我不知道我是否能很好地解释解决方案。所以 我有超文本标记语言 clearfix类的实现如下所述 我想要这个。picture div位于左侧和右侧。description div保持在右侧。所以我写了这个CSS 到现在为止,一切都很好。 但有时,没有图片出现。在这种情况下,我想要那个。description div扩展到所有的。容器div宽度。因此,我尝试删除

  • Jasmine还允许开发人员跳过一个或多个测试用例。 这些技术可以在Spec level或Suite level 。 根据应用程序的不同,此块可分别称为Skipping Spec和Skipping Suite 。 在以下示例中,我们将学习如何使用“x”字符跳过特定的Spec或Suite 。 跳过规格 我们将在语句之前使用“x”修改前面的示例。 describe('This custom match

  • 在上面的例子中,我希望项目1在左侧,项目2和3在右侧的页面使用CSS3 FlexBox。 提前致谢

  • 下面是我的代码: null null 为什么类名为“menu”的div没有浮动到右侧? 我希望div浮动到其父项右侧。 谢谢.