有关css伪类:after清除浮动的问题
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了有关css伪类:after清除浮动的问题相关的知识,希望对你有一定的参考价值。
.clear:after
content=".";
/*visibility:hidden; *暂时注释/
display:block;
height:0;
clear:both;
这里面的display不是block么,那么应该要换行显示,那要怎么清除浮动呢,麻烦讲解下
【浮动产生负作用 】
1、背景不能显示
由于浮动产生,如果对父级设置了(CSS background背景)CSS背景颜色或CSS背景图片,而父级不能被撑开,所以导致CSS背景不能显示。
2、边框不能撑开
如上图中,如果父级设置了CSS边框属性(css border),由于子级里使用了float属性,产生浮动,父级不能被撑开,导致边框不能随内容而被撑开。
3、margin padding设置值不能正确显示
由于浮动导致父级子级之间设置了css padding、css margin属性的值不能正确表达。特别是上下边的padding和margin不能正确显示。
【css解决浮动,清除浮动方法】
方法一:
<div class="fl"></div>
<div class="fr"></div>
<div class="clear"></div>
</div>
.clear clear:both; height:0; font-size:0; line-height:0; overflow:hidden;
可以不用对父级设置高度 也无需技术父级高度,方便适用,但会多加CSS和html标签。
方法二:对父级设置适合CSS高度
方法三:父级div定义 overflow:hidden
对父级CSS选择器加overflow:hidden样式,可以清除父级内使用float产生浮动。优点是可以很少CSS代码即可解决浮动产生。
方法四:
.cle:after, .clearfix:after, .clear_f:after, .cle_float:aftervisibility:hidden; display:block; font-size:0; content:'\\20'; clear:both; height:0;
.cle, .clearfix, .clear_f, .cle_float*zoom:1
在父级加上一个class
参考技术A 清除浮动的关键是这句好不好:clear:both; 参考技术B 清除浮动时就是要用block元素呀追问那
.clear:after
content=".";
/*visibility:hidden; *暂时注释/
display:block;
height:0;
clear:both;
这段是不是对自己进行清除.清除浮动后 在后面再写div就能到右边去了?这个div不用写float:right?
清除class="clear"的那个元素的浮动。
比如说clear那个元素是float:left的,
在没加clear类之前,直接在后面加个div,会显示成两个div并列。
加了clear后,第二个会显示在第一个下方。
浮动会影响自己及之后的元素,清除浮动就是清除对之后元素的影响。
知道css有个content属性吗?有什么作用?有什么应用?可以伪类清除浮动
知道。css的content属性专门应用在 before/after 伪元素上,用来插入生成内容。最常见的应用是利用伪类清除浮动。
.clearfix:after { content:"."; //这里利用到了content属性 display:block; height:0; visibility:hidden; clear:both; } .clearfix { *zoom:1; }
after伪元素通过 content 在元素的后面生成了内容为一个点的块级素,再利用clear:both清除浮动。
那么问题继续还有,知道css计数器(序列数字字符自动递增)吗?如何通过css content属性实现css计数器?
答案:css计数器是通过设置counter-reset 、counter-increment 两个属性 、及 counter()/counters()一个方法配合after / before 伪类实现。
以上是关于有关css伪类:after清除浮动的问题的主要内容,如果未能解决你的问题,请参考以下文章
知道css有个content属性吗?有什么作用?有什么应用?可以伪类清除浮动