您现在的位置是:网站首页> 编程资料编程资料
一文掌握CSS 属性display:flow-root声明css之display属性之inline-block布局实现详解CSS中display flex整理(布局利器) 浅析css中使用border属性与display属性的方法CSS3中的display:grid,网格布局介绍
2021-09-03
821人已围观
简介 这篇文章主要介绍了CSS 属性display:flow-root声明的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
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 { outline: solid deepskyblue; } img { float: left; }
结果轮廓都合在一起了,如下图所示:

此时,只要给 元素设置 display:flow-root ,浮动导致元素高度塌陷的问题就不存在了:
p { display: flow-root; }效果如下截图所示:

类似的,margin属性合并的现象也可以使用 display:flow-root 阻止。
HTML代码如下:
margin: 2em;
margin: 2em;
CSS如下:
.box { background-color: #f0f3f9; } .box p { outline: solid deepskyblue; margin: 2em; } .flow-root { display: flow-root; }结果上面的容器元素margin被穿过去了,而下面的容器元素,因为设置了 display:flow-root ,所以margin穿透被阻止了,于是,里面 元素占据的空间就显得较大,如下图所示:

以上两个例子均有demo可以体验,您可以狠狠地点击这里: display:flowt-root作用示意demo
display:flow-root 还可以和浮动属性配合,实现两栏自适应的布局效果。
例如:
拼多多暴涨7%,市值突破700亿美元,超越京东。而黄峥个人财富也处于内地第三大富豪
.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容器框。
根据是否包含格式化上下文属性(如 position 、 float 或 overflow )以及元素本身是否参与块或内联格式上下文, display:flow 元素要么为其内容建立新的块格式上下文(BFC),要么将其内容集成到其父格式上下文中。
display:flow 目前兼容性不详,估计目前没几个浏览器支持。
等日后成熟再展开介绍。
到此这篇关于一文掌握CSS display:flow-root声明的文章就介绍到这了,更多相关CSS display:flow-root内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
相关内容
- CSS实现3D书本效果的示例代码纯CSS3实现3D旋转书本效果基于HTML5/CSS3实现的书本翻页3D动画特效源码 鼠标滑过书本自动翻页
- 修复一个因为scrollbar占据空间导致的bug问题CSS3自定义滚动条样式 ::webkit-scrollbar的示例代码详解纯css修改浏览器scrollbar滚动条样式示例CSS教程:scrollbar的属性知识及样式分类介绍
- 详解CSS3实现响应式手风琴效果CSS3防疫知识图文响应式布局代码CSS3响应式个人名片图文布局代码css3 响应式媒体查询的示例代码HTML5 图片悬停放大的实现代码示例html用title属性实现鼠标悬停显示文字 html+css实现响应式卡片悬停效果
- css实现朋友圈照片排列布局的代码CSS实现动态图片的九宫格布局的实例代码css3 图片圆形显示 如何CSS将正方形图片显示为圆形图片布局DIV+CSS中让布局、背景图片、文字内容居中的方法css中文字加图片的布局实现input输入框中有图片怎么使用css布局实现用CSS布局复杂的图片边框实例
- CSS通过letter-spacing属性 控制字与字间隔 IE7与FF下的letter-spacing属性兼容性写法inline-block空隙之css letter-spacing与字体大小/字体关系数据表CSS文字控制之letter-spacing和word-spacing
- css 布局 之 两端布局的实例代码 (利用父级负的margin)css如何利用负margin技术实现平均布局css布局之负margin妙用及其他实现CSS中使用负margin值来调整居中位置css利用负margin实现平均布局的示例
- CSS3实现淘宝留白的方法css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- css实现背景虚化效果的示例代码CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- 浅谈Flex布局与缩放比例计算Flex布局做出自适应页面(语法和案例)详解flex布局中保持内容不超出容器的解决办法flex弹性盒布局最后一行左对齐的实现思路深入浅析CSS3中的Flex布局整理详解CSS中的flex布局css用Flex布局制作简易柱状图的实现flex布局兼容性问题小结详解flex布局的元素如何分配容器的剩余空间flex布局被子元素撑开如何保持内容不超出容器的方法flex布局实现左侧文字溢出省略右侧文字自适应
- CSS样式书写顺序和命名规范及注意事项CSS使用BEM命名规范实践值得收藏的CSS命名规范(规则)常用的CSS命名规则 好的 CSS 命名规范可以节约 Debug 时间css 命名:BEM, scoped css, css modules 与 css-in-js详解CSS规范BEM CSS和OOCSS的示例代码详解详解css BEM书写规范 从QQtabBar看css命名规范BEM的详细介绍

