网站首页 > 技术文章 正文
浮动元素不同于普通文档流的元素,它们的高度不会加到父元素上。我们来看一个例子:
上图中main模块下包含了一个标题和4个块,其中四个高度不同的块被包含在一个div容器中。页面想要的效果是四个块在底部两列布局,并保持整齐。
我们给main元素添加了一个背景色(#ddd),但是只体现到了标题(h1)上。要解决这个问题,就要清除浮动:
在给main加上清除浮动后,容器的高度就正常了。注意我们使用的是给main添加了伪元素来清除浮动。
虽然我们解决了main高度的问题,还有一个问题:浮动元素的外边距不会折叠到浮动容器的外部,非浮动元素的外边距则会正常折叠。现象就是标题的外边距在容器外面折叠了,main和标题顶部之间的间距不见了。我们换一种清除浮动的写法:
上面使用了display: table,而不是display: block。给::before和::after伪元素都加上这一属性,所有子元素的外边距都会包含在容器的顶部和底部之间。这种清除浮动的的效果更加符合预期。
为什么使用display: table能够生效呢?
因为创建一个display: table元素,也就是在元素内隐式创建了一个表格行和一个单元格。外边距无法通过单元格元素折叠,所以也就无法通过设置了display: table的伪元素折叠。
还有一个问题,块1的高度比块2高,导致块3不是排列在块1的正下方,而是到了块1的右下角。要想修复这个问题也很简单:清除第三个浮动元素上面的浮动。更通用的做法是,清除每一行第一个元素上面的浮动:
现在我们使用float实现了一个两行两列的布局,解决了浮动属性的一些常见问题,总结了一个推荐的写法,你学到了吗?欢迎在评论区留言和我交流~
- 上一篇: 快过年了~我用CSS画了个灯笼,赶紧来白嫖
- 下一篇: css如何处理单行、多行文本溢出的省略
猜你喜欢
- 2024-11-14 Python Web全栈之旅09--Web前端●CSS浮动
- 2024-11-14 CSS 面试题:CSS的权重与优先级 css权重和优先级
- 2024-11-14 HTML/CSS 备忘录 - 12. CSS 浮动与定位
- 2024-11-14 Web前端开发-CSS布局-浮动和定位-入门干货
- 2024-11-14 前端初学者必看,这10 个CSS3 属性,你需要熟悉
- 2024-11-14 CSS学习之权重 css权重的计算方式
- 2024-11-14 css 绘制心形 css版心
- 2024-11-14 CSS 函数那些事(二)你不知道的 attr()
- 2024-11-14 如何解决after和before的兼容性 before和after用法
- 2024-11-14 CSS-西安钟楼 西安钟楼视频讲解
- 标签列表
-
- content-disposition (47)
- nth-child (56)
- math.pow (44)
- 原型和原型链 (63)
- canvas mdn (36)
- css @media (49)
- promise mdn (39)
- readasdataurl (52)
- if-modified-since (49)
- css ::after (50)
- border-image-slice (40)
- flex mdn (37)
- .join (41)
- function.apply (60)
- input type number (64)
- weakmap (62)
- js arguments (45)
- js delete方法 (61)
- blob type (44)
- math.max.apply (51)
- js (44)
- firefox 3 (47)
- cssbox-sizing (52)
- js删除 (49)
- js for continue (56)
- 最新留言
-