为了账号安全,请及时绑定邮箱和手机立即绑定

不明白清除浮动那里,为什么用:after

.article-preview:after{     
    content: '';
    display: block;
    clear: both;
}


为什么用after????

正在回答

4 回答

清除浮动有以下几种方法:

1、


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

【一丝冰凉】 /2012-05-07/已有45738人看过/层叠之美


 浮动(float),一个我们即爱又恨的属性。爱,因为通过浮动,我们能很方便地布局; 恨,浮动之后遗留下来太多的问题需要解决,特别是IE6-7(以下无特殊说明均指 windows 平台的 IE浏览器)。也许很多人都有这样的疑问,浮动从何而来?我们为何要清除浮动?清除浮动的原理是什么?本文将一步一步地深入剖析其中的奥秘,让浮动使用起来更加得心应

为何要闭合浮动?

要解答这个问题,我们得先说说CSS中的定位机制:普通流,浮动,绝对定位 (其中"position:fixed" 是 "position:absolute" 的一个子类)。

1)普通流:很多人或者文章称之为文档流或者普通文档流,其实标准里根本就没有这个词。如果把文档流直译为英文就是 document flow ,但标准里只有另一个词,叫做 普通流 (normal flow),或者称之为常规流。但似乎大家更习惯文档流的称呼,因为很多中文翻译的书就是这么来的。比如《CSS Mastery》,英文原书中至始至终都只有普通流 normal flow(普通流) 这一词,从来没出现过document flow (文档流)

2)浮动:浮动的框可以左右移动,直至它的外边缘遇到包含框或者另一个浮动框的边缘。浮动框不属于文档中的普通流,当一个元素浮动之后,不会影响到 块级框的布局而只会影响内联框(通常是文本)的排列,文档中的普通流就会表现得和浮动框不存在一样,当浮动框高度超出包含框的时候,也就会出现包含框不会 自动伸高来闭合浮动元素(“高度塌陷”现象)。顾名思义,就是漂浮于普通流之上,像浮云一样,但是只能左右浮动。

正是因为浮动的这种特性,导致本属于普通流中的元素浮动之后,包含框内部由于不存在其他普通流元素了,也就表现出高度为0(高度塌陷)。在实际布局中,往往这并不是我们所希望的,所以需要闭合浮动元素,使其包含框表现出正常的高度。


看一下清理浮动的各种方法:

1)添加额外标签

这是在学校老师就告诉我们的 一种方法,通过在浮动元素末尾添加一个空的标签例如 <div style=”clear:both”></div>,其他标签br等亦可。

 <div class="wrap" id="float1">

<h2>1)添加额外标签</h2>

<div class="main left">.main{float:left;}</div>

<div class="side left">.side{float:right;}</div>

<div style="clear:both;"></div>

</div>

<div class="footer">.footer</div>

2)使用 br标签和其自身的 html属性

这个方法有些小众,br 有 clear=“all | left | right | none” 属性

 <div class="wrap" id="float2">

<h2>2)使用 br标签和其自身的 html属性</h2>

<div class="main left">.main{float:left;}</div>

<div class="side left">.side{float:right;}</div>

<br clear="all" />

</div>

<div class="footer">.footer</div>

3)父元素设置 overflow:hidden

通过设置父元素overflow值设置为hidden;在IE6中还需要触发 hasLayout ,例如 zoom:1;

 <div class="wrap" id="float3" style="overflow:hidden; *zoom:1;">

<h2>3)父元素设置 overflow </h2>

<div class="main left">.main{float:left;}</div>

<div class="side left">.side{float:right;}</div>

</div>

<div class="footer">.footer</div>

4)父元素设置 overflow:auto 属性

同样IE6需要触发hasLayout,演示和3差不多

5)父元素也设置浮动

6)父元素设置display:table

7)使用:after 伪元素

2 回复 有任何疑惑可以回复我~

所谓清除浮动,目的是让下面的元素不会受到上面浮动的影响。  :after伪元素在浮动的父级元素后面增加了一个content为' '的block元素。而且这个block元素两边都不允许出现浮动元素,下面的浮动元素只能另起一行浮动。这里:after这个伪元素形成了一道看不见的“防护墙”,让防护墙的两边各自浮动而不受影响

0 回复 有任何疑惑可以回复我~

首先你要理解:after选择器,是指在元素的内容之后插入新内容清除浮动

如同下面代码:

<div>

<div style="float:left"></div>

<div style="float:right"></div>

</div>

<div style="clear:both"></div>

1 回复 有任何疑惑可以回复我~

因为父元素的最后清除浮动,父元素才能将所有子元素包括,要保证兼容性还应该在before也应用相同样式的

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
HTML5和CSS3扁平化风格博客
  • 参与学习       86811    人
  • 解答问题       383    个

HTML5与CSS3搭建超酷扁平化风格博客

进入课程

不明白清除浮动那里,为什么用:after

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信