搜索
首页web前端css教程浅析CSS中的浮动与清理
浅析CSS中的浮动与清理Apr 15, 2017 am 09:05 AM
css

作为前端写了很多页面布局,但是浮动这块一直是我似懂非懂的盲点,一方面用浮动能实现很多布局,另一方面浮动造成的影响又会破坏布局让人头疼,所以今天就特地写篇博文解决这块盲点。

本文主要讨论以下几个问题:
1.浮动的原始用途
2.浮动为什么会有文本环绕效果
3.如何清理浮动造成的影响

浮动的原始用途

以下内容来自张鑫旭大神的《CSS float浮动的深入研究、详解及拓展(一)》:

假设现在CSS中没有浮动(float)属性,那么会变成一个什么样子。我们会发现,目前流行采用浮动方法实现的无论是分栏布局,还是列表排列我们都可以用其他一些CSS属性(不考虑table)代替实现,唯一一个实现不了的就是“文字环绕图片”,我是想不出来能有什么方法可以让文字环绕图片显示。好,这个替代不了的作用才是float真正的意义所在。

总结起来一句话:实现文本环绕图片的效果。

浮动为什么会有文本环绕效果

产生这个疑问主要来自于以往的印象:

浮动的元素是脱离文档流的。

咦?你都脱离文档流了不是应该和下方未浮动的元素重叠吗,为什么文本还能环绕你呢?

这个问题一直困扰着我,直到我看到《精通CSS》这本书。文中写到:

浮动会让元素脱离文档流,不再影响不浮动的元素。实际上,并不完全如此。如果浮动的元素后面有一个文档流中的元素,那么这个元素的框会表现得像浮动根本不存在一样。但是,框的文本内容会受到浮动元素的影响,会移动以留出空间。

也就是说,浮动元素的确脱离了文档流,因此文档流中的块框会无视浮动的元素,但是文本不会。这点与绝对定位的脱离文档流不一样。

知乎上张秋怡学姐的回答也印证了这一观点。

补充一点:文档流这个说法其实不准确,在W3C标准中,只有普通流(normal flow),但是许多国内文章和翻译的书籍里用的都是文档流,久而久之大家就都用文档流的说法了。

如何清理浮动造成的影响

其实浮动带来的影响主要是

1.元素脱离普通流造成的父元素高度塌陷
2.下方非文本元素与浮动元素重叠,破坏了原本布局

要清理这些影响,很多人都知道用clear属性,为什么clear能清除浮动呢?

有两种说法:
1.浏览器在设置clear元素的顶上添加足够多的外边距,使元素上边框边界垂直下降到浮动元素下外边距的下面。
2.在设置clear元素的上外边距之上增加清除空间,而外边距本身不改变。

前者是CSS1和CSS2的实现原理,后者是CSS2.1的实现原理。但无论哪种都达到了给浮动的元素留出了垂直空间,看上去清除了浮动的效果。同时,在设置clear元素之上填充的空间是实际存在于普通流中的。因此,父元素高度被撑开了。

关于清除浮动,其实还有许多方法。在《那些年我们一起清除过的浮动》这篇文章里,将清除浮动的方法简单分为两类:

1.通过在浮动元素的末尾添加一个空元素,设置 clear:both属性,after伪元素其实也是通过 content 在元素的后面生成了内容为一个点的块级元素;
2.通过设置父元素 overflow 或者display:table 属性来闭合浮动。

几乎所有清除浮动的方法都可以归纳到这两类中,这里结合上面的博文谈一谈,添加伪元素的方法:

1.display: block,使生成的元素以块级元素显示,占满剩余空间。
2.在content中添加一个点,因为这个字符非常小。
3.设置height为0,因为不希望这个新的内容占据空间破坏布局高度。
4.将visibility设置为hidden,使生成的内容不可见,允许可能被生成的内容盖住的部分可以点击和交互。
5.clear: both清理浮动的影响

代码如下:

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

这种方法在大多数现代浏览器中都是有效的,也是比较推荐的。至于其他方法网上有很多,这里就不详细讲了。

本文借鉴了部分其他博客与文档,附上链接:

参考链接:

CSS clear属性

CSS 浮动

理解CSS浮动与清除浮动

那些年我们一起清除过的浮动

noraml flow

CSS float浮动的深入研究、详解及拓展(一)

张秋怡的回答


作为前端写了很多页面布局,但是浮动这块一直是我似懂非懂的盲点,一方面用浮动能实现很多布局,另一方面浮动造成的影响又会破坏布局让人头疼,所以今天就特地写篇博文解决这块盲点。

本文主要讨论以下几个问题:
1.浮动的原始用途
2.浮动为什么会有文本环绕效果
3.如何清理浮动造成的影响

浮动的原始用途

以下内容来自张鑫旭大神的《CSS float浮动的深入研究、详解及拓展(一)》:

假设现在CSS中没有浮动(float)属性,那么会变成一个什么样子。我们会发现,目前流行采用浮动方法实现的无论是分栏布局,还是列表排列我们都可以用其他一些CSS属性(不考虑table)代替实现,唯一一个实现不了的就是“文字环绕图片”,我是想不出来能有什么方法可以让文字环绕图片显示。好,这个替代不了的作用才是float真正的意义所在。

总结起来一句话:实现文本环绕图片的效果。

浮动为什么会有文本环绕效果

产生这个疑问主要来自于以往的印象:

浮动的元素是脱离文档流的。

咦?你都脱离文档流了不是应该和下方未浮动的元素重叠吗,为什么文本还能环绕你呢?

这个问题一直困扰着我,直到我看到《精通CSS》这本书。文中写到:

浮动会让元素脱离文档流,不再影响不浮动的元素。实际上,并不完全如此。如果浮动的元素后面有一个文档流中的元素,那么这个元素的框会表现得像浮动根本不存在一样。但是,框的文本内容会受到浮动元素的影响,会移动以留出空间。

也就是说,浮动元素的确脱离了文档流,因此文档流中的块框会无视浮动的元素,但是文本不会。这点与绝对定位的脱离文档流不一样。

知乎上张秋怡学姐的回答也印证了这一观点。

补充一点:文档流这个说法其实不准确,在W3C标准中,只有普通流(normal flow),但是许多国内文章和翻译的书籍里用的都是文档流,久而久之大家就都用文档流的说法了。

如何清理浮动造成的影响

其实浮动带来的影响主要是

1.元素脱离普通流造成的父元素高度塌陷
2.下方非文本元素与浮动元素重叠,破坏了原本布局

要清理这些影响,很多人都知道用clear属性,为什么clear能清除浮动呢?

有两种说法:
1.浏览器在设置clear元素的顶上添加足够多的外边距,使元素上边框边界垂直下降到浮动元素下外边距的下面。
2.在设置clear元素的上外边距之上增加清除空间,而外边距本身不改变。

前者是CSS1和CSS2的实现原理,后者是CSS2.1的实现原理。但无论哪种都达到了给浮动的元素留出了垂直空间,看上去清除了浮动的效果。同时,在设置clear元素之上填充的空间是实际存在于普通流中的。因此,父元素高度被撑开了。

关于清除浮动,其实还有许多方法。在《那些年我们一起清除过的浮动》这篇文章里,将清除浮动的方法简单分为两类:

1.通过在浮动元素的末尾添加一个空元素,设置 clear:both属性,after伪元素其实也是通过 content 在元素的后面生成了内容为一个点的块级元素;
2.通过设置父元素 overflow 或者display:table 属性来闭合浮动。

几乎所有清除浮动的方法都可以归纳到这两类中,这里结合上面的博文谈一谈,添加伪元素的方法:

1.display: block,使生成的元素以块级元素显示,占满剩余空间。
2.在content中添加一个点,因为这个字符非常小。
3.设置height为0,因为不希望这个新的内容占据空间破坏布局高度。
4.将visibility设置为hidden,使生成的内容不可见,允许可能被生成的内容盖住的部分可以点击和交互。
5.clear: both清理浮动的影响

代码如下:

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

这种方法在大多数现代浏览器中都是有效的,也是比较推荐的。至于其他方法网上有很多,这里就不详细讲了。


以上是浅析CSS中的浮动与清理的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
利用CSS怎么创建渐变色边框?5种方法分享利用CSS怎么创建渐变色边框?5种方法分享Oct 13, 2021 am 10:19 AM

利用CSS怎么创建渐变色边框?下面本篇文章给大家分享CSS实现渐变色边框的5种方法,希望对大家有所帮助!

css ul标签怎么去掉圆点css ul标签怎么去掉圆点Apr 25, 2022 pm 05:55 PM

在css中,可用list-style-type属性来去掉ul的圆点标记,语法为“ul{list-style-type:none}”;list-style-type属性可设置列表项标记的类型,当值为“none”可不定义标记,也可去除已有标记。

css与xml的区别是什么css与xml的区别是什么Apr 24, 2022 am 11:21 AM

区别是:css是层叠样式表单,是将样式信息与网页内容分离的一种标记语言,主要用来设计网页的样式,还可以对网页各元素进行格式化;xml是可扩展标记语言,是一种数据存储语言,用于使用简单的标记描述数据,将文档分成许多部件并对这些部件加以标识。

css3怎么实现鼠标隐藏效果css3怎么实现鼠标隐藏效果Apr 27, 2022 pm 05:20 PM

在css中,可以利用cursor属性实现鼠标隐藏效果,该属性用于定义鼠标指针放在一个元素边界范围内时所用的光标形状,当属性值设置为none时,就可以实现鼠标隐藏效果,语法为“元素{cursor:none}”。

css怎么实现英文小写转为大写css怎么实现英文小写转为大写Apr 25, 2022 pm 06:35 PM

转换方法:1、给英文元素添加“text-transform: uppercase;”样式,可将所有的英文字母都变成大写;2、给英文元素添加“text-transform:capitalize;”样式,可将英文文本中每个单词的首字母变为大写。

css怎么设置i不是斜体css怎么设置i不是斜体Apr 20, 2022 am 10:36 AM

在css中,可以利用“font-style”属性设置i元素不是斜体样式,该属性用于指定文本的字体样式,当属性值设置为“normal”时,会显示元素的标准字体样式,语法为“i元素{font-style:normal}”。

rtl在css是什么意思rtl在css是什么意思Apr 24, 2022 am 11:07 AM

在css中,rtl是“right-to-left”的缩写,是从右往左的意思,指的是内联内容从右往左依次排布,是direction属性的一个属性值;该属性规定了文本的方向和书写方向,语法为“元素{direction:rtl}”。

怎么设置rotate在css3的旋转中心点怎么设置rotate在css3的旋转中心点Apr 24, 2022 am 10:50 AM

在css3中,可以用“transform-origin”属性设置rotate的旋转中心点,该属性可更改转换元素的位置,第一个参数设置x轴的旋转位置,第二个参数设置y轴旋转位置,语法为“transform-origin:x轴位置 y轴位置”。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境