栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

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

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

在您询问的选项中:

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



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/575582.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号