一文掌握CSS 属性display:flow-root声明

所属分类: 网页制作 / CSS 阅读数: 878
收藏 0 赞 0 分享

byzhangxinxu from https://www.zhangxinxu.com/wordpress/?p=9404

本文欢迎分享与聚合,全文转载就不必了,尊重版权,圈子就这么大,若急用可以联系授权。

一、Safari浏览器支持了

display:flow-root 刚出来的时候,我一看兼容性,啧啧,不知道猴年马月才能用在生产环境,今天又遇到这厮,一查兼容性,嘿,小子,不错嘛,Safari浏览器从版本13开始支持了,距离流行使用指日可待。

二、display:flow-root干嘛用的?

元素,无论是内联元素,还是原本就是块级元素,在应用 display:flow-root 声明后,都会变成块级元素,同时这个元素会建立新的块级格式上下文,也就是业界常说的BFC。

关于BFC,可以参考我之前的这篇经典文章:“ CSS深入理解流体特性和BFC特性下多栏自适应布局 ”。

BFC除了可以用来布局之外,还有清除浮动,以及去除margin合并现象的作用,因此, display:flow-root 也有类似的作用,相比float浮动,position绝对定位,或者overflow隐藏,inline-block等特性产生的块级格式上下文, display:flow-root 不会给元素带来额外的副作用,例如 overflow:hidden 虽然可以去除浮动的干扰,但是,有可能会让子元素无法定位在容器外部。

使用 display:flow-root 就不会有这样的担忧。

例如下面这个例子,容器有轮廓,子元素浮动:

<p><img src="mm.jpg"></p>
p {
    outline: solid deepskyblue;    
}
img {
    float: left;
}

结果轮廓都合在一起了,如下图所示:

此时,只要给 <p> 元素设置 display:flow-root ,浮动导致元素高度塌陷的问题就不存在了:

p {
    display: flow-root;
}

效果如下截图所示:

类似的,margin属性合并的现象也可以使用 display:flow-root 阻止。

HTML代码如下:

<div class="box">
    <p>margin: 2em;</p>
</div>
<div class="box flow-root">
    <p>margin: 2em;</p>
</div>

CSS如下:

.box {
    background-color: #f0f3f9;    
}
.box p {
    outline: solid deepskyblue;
    margin: 2em;
}
.flow-root {
    display: flow-root;
}

结果上面的容器元素margin被穿过去了,而下面的容器元素,因为设置了 display:flow-root ,所以margin穿透被阻止了,于是,里面 <p> 元素占据的空间就显得较大,如下图所示:

以上两个例子均有demo可以体验,您可以狠狠地点击这里: display:flowt-root作用示意demo

display:flow-root 还可以和浮动属性配合,实现两栏自适应的布局效果。

例如:

<div class="box flow-root">
    <img src="mm.jpg">
    <p class="flow-root">拼多多暴涨7%,市值突破700亿美元,超越京东。而黄峥个人财富也处于内地第三大富豪</p>
</div>
.box img {
    float: left;
    margin-right: 20px;
}
.box p {
    background-color: #f0f3f9;
    padding: 10px;
}
.flow-root {
    display: flow-root;
}

实时效果如下:

拼多多暴涨7%,市值突破700亿美元,超越京东。而黄峥个人财富也处于内地第三大富豪

三、结语

总结下本文要点

display:flow-root 可以让元素块状化,同时包含格式化上下文BFC,可以用来清除浮动,去除 margin 合并,实现两栏自适应布局等。

display:flow-roo t可以在部分项目中使用了。

display:flow

display 属性还支持一个目前处于试验形式的值,名为 flow ,表现为元素可能是内联框盒子,也可能是块级框盒子。

究竟渲染成哪个盒子与外部元素的显示类型相关,

要么生成内联格式化上下文,要么生成块级格式化上下文。如果元素外部显示类型为inline或run-in,并且元素参与block或inline格式上下文中,则元素表现为inline框,否则表现为block容器框。

根据是否包含格式化上下文属性(如 positionfloatoverflow )以及元素本身是否参与块或内联格式上下文, display:flow 元素要么为其内容建立新的块格式上下文(BFC),要么将其内容集成到其父格式上下文中。

display:flow 目前兼容性不详,估计目前没几个浏览器支持。

等日后成熟再展开介绍。

到此这篇关于一文掌握CSS display:flow-root声明的文章就介绍到这了,更多相关CSS display:flow-root内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

更多精彩内容其他人还在看

Opera中国的WEB标准课程

网页制作Webjx文章简介:在这篇文章里,我要向大家介绍我和其他很多人花费数月时间开发的一个课程——Web标准课程,该课程旨在向大家提供Web设计和开发的坚实基础,无论读者是谁,此教程完全免费、可访问,并且不需要预备知识。当然,我主要还
收藏 0 赞 0 分享

CSS样式表渐进增强的基本概念

网页制作Webjx文章简介:如果你挠着头想弄清楚优雅降级和渐进增强的区别,我告诉你,这是视角问题。优雅降级和渐进增强都考虑网站在各种设备的各种浏览器上如何良好运转。两者区别的关键在于它们各自关注的焦点,以及这种关注对工作流程的影响
收藏 0 赞 0 分享

简单介绍Web Developer插件制作网页

网页制作Webjx文章简介:Firefox浏览器是一个良好支持W3C标准的开放源代码的浏览器,拥有Linux/Windows/Mac版本。因为Firefox浏览器良好支持W3C标准,所以使用Firefox来调试网页是非常好的。 Firefox浏览器是
收藏 0 赞 0 分享

CSS布局带来的巨大影响:CSS display属性值

网页制作Webjx文章简介:网页元素应用上那些与表格相关的display属性值后,能够模仿出与表格相同的特性。我将会在该文中给大家演示这种方法给CSS布局带来的巨大影响。 应原书编辑要求,先在文章顶部给出链接:《Everything You
收藏 0 赞 0 分享

用div css模拟表格对角线

这只是探讨一种CSS模拟表格对角线的用法,实际在工作中可能觉得这样做有点小题大作,这不是本主题讨论的重点。如果对此深以为然的朋友,请一笑过之 首先声明: 这只是探讨一种CSS模拟表格对角线的
收藏 0 赞 0 分享

IE Firefox在css中的差别 (部分)

1、单位问题 问题:任何距离的数值ie可以不加单位,ff必须要求写单位(0除外) 解决:写全单位如padding:0px; 2、水平居中 问题:div里的内容,ie默认为center,而ff默认left 解决:mairgin:0px auto; 3、高度问题
收藏 0 赞 0 分享

不用js可以实现信息提示效果

[code] <style> body { font:verdena; font-size:14px; color:#000 } h1{ font:verdena; font-size:22px; color:#000 } h2{ font:verdena;
收藏 0 赞 0 分享

CSS解决未知高度的垂直水平居中自适应问题

今天有人问起,晚上试着写出来,供参考; 以下代码兼容主流浏览器IE6、IE7、Firefox、Opera。 从最简单的开始………… 一、如何让一个DIV水平居中? 这个简单不作过多说明! [code] <st
收藏 0 赞 0 分享

CSS cursor 属性 -- 鼠标指针样式效果

取值: [ [<uri> ,]* [ auto | crosshair | default | pointer | move | e-resize | ne-resize | nw-resize | n-resize | se-resize | sw-resize |
收藏 0 赞 0 分享

css 简单区别ie6,ie7,firefox的写法

同一样式里可以这样 [code] margin:17px; FF +margin:17px; IE6 IE7 _margin:17px; IE6 [/code] 按这个顺序,刚好区分开三个浏览器
收藏 0 赞 0 分享
查看更多