博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
利用clear清除浮动的一些问题
阅读量:5900 次
发布时间:2019-06-19

本文共 1598 字,大约阅读时间需要 5 分钟。

下面这段代码是用来清除浮动带来的高度塌陷问题

.clearfix:before {    content: ".";     display: block;     height: 0;     clear: both;     visibility: hidden;}

Question 1: 上面的代码的能够实现清除浮动的问题吗?

Answer: Can't. 因为clear属性只能控制元素本身与前面的浮动元素的关系。在本例中,使用:before伪元素明显位于所有子元素之前,故而clear属性不会因后面的浮动元素产生任何作用效果。 clear属性的官方定义可以查看 。那么应该如何修改呢?将:before换成:after即可。最终代码如下:

.clearfix:after {    content: ".";     display: block;     height: 0;     clear: both;     visibility: hidden;}

Question 2: content属性的内容能改成空吗content: '';

Answer: Yes. 因为设置了 height:0;visibility: hidden。 如果设置了content:'';,那么 height:0;visibility: hidden和 可以去掉吗? 当然可以,因为块元素没有内容就不会有高度咯。

更改后的代码如下:

.clearfix:after {    content: "";     display: block;    clear: both;}

Question 3: display属性的内容能改成 inlineinline-block 吗?

Answer: 不能。 我们要明白float属性的初衷————让文字环绕图片展示。翻译成另外一句话:内联级别的元素会环绕浮动元素展示。那么为什么 display: block;可以解决高度塌陷的问题呢。 因为 clear属性的含义是不让元素本身与浮动元素的边界相邻。如果块级元素要不与块级元素边界相邻,只有换到下一行展示。也正为换行,才将父元素到高度撑开了,正式上面的代码解决高度塌陷的原理。

Question 4: 下面到div元素会存在高度塌陷问题吗?

历史的天空

Answer: 存在。为什么呢?要知道 clear属性中, clear:left;clear:right; 的区别。

  • left : 不与左浮动的元素产生边界接触;
  • right : 不与右浮动的元素产生边界接触;
  • both : 不与左浮动和右浮动的元素产生边界接触;

所以上面的代码不会解决高度塌陷到问题。

如果有如下代码:

1
2
3
1
2
3
å

你会发现,两个div的展示效果是相同的。也就是说,如果前面同时存在左浮动和右浮动到元素,那么clear属性值无论设成left 还是right都无关紧要。 反过来想,如果clear属性设成 both,那么无论前面的元素是左浮动还是右浮动,都无关紧要。这也是clearfix通常设置 clear:both;的原因。

注意一点,我们一直在说 解决 高度塌陷都问题,从来没有说清除浮动。 是因为本质上,浮动并没被清除,我们只是利用clear属性解决了浮动元素带来的父级元素高度塌陷问题。而且clear属性影响也只是设置clear属性的元素本身,而不是浮动元素。

转载地址:http://mjesx.baihongyu.com/

你可能感兴趣的文章
华为吴晟:分布式监控系统的设计与实现
查看>>
[deviceone开发]-do_Webview的基本示例
查看>>
亚马逊Alexa借助神经网络生成播音员声音
查看>>
比特大陆新一轮裁员50%,回应称系人员调整
查看>>
[nginx文档翻译系列] 控制nginx
查看>>
将 Measurements 和 Units 应用到物理学
查看>>
数据拷贝的实现
查看>>
关于责任和业务(r11笔记第60天)
查看>>
SQL优化常用方法44
查看>>
Alibaba Canal Manager Model 配置管理实现
查看>>
在浏览器中输入Google.com并且按下回车之后发生了什么?(转)
查看>>
Git 1.9.5.msysgit.1
查看>>
《 测试反模式:有效规避常见的92种测试陷阱》—— 2.2 测试类型相关陷阱
查看>>
开源中国 2013 大记事
查看>>
《OpenGL ES应用开发实践指南:Android卷》—— 1.6 小结
查看>>
《需求设计:构建用户想要和需要的产品》——1.3 像工程学那样来开发IT应用程序...
查看>>
Google:这个安卓新漏洞其实没什么大不了
查看>>
《电路分析导论(原书第12版)》一2.6 安时数
查看>>
支撑起整个互联网时代的 7 款开源软件
查看>>
Android 平台全球网络流量首次超越 iOS
查看>>