有关css伪类:after清除浮动的问题

.clear:after{content=".";/*visibility:hidden;*暂时注释/display:block;height:0;clear:both;... .clear:after{
content=".";
/*visibility:hidden; *暂时注释/
display:block;
height:0;
clear:both;
}

这里面的display不是block么,那么应该要换行显示,那要怎么清除浮动呢,麻烦讲解下
展开
 我来答
Oo_sky
推荐于2017-09-05 · TA获得超过1169个赞
知道小有建树答主
回答量:372
采纳率:25%
帮助的人:276万
展开全部

【浮动产生负作用 】

1、背景不能显示
由于浮动产生,如果对父级设置了(CSS background背景)CSS背景颜色或CSS背景图片,而父级不能被撑开,所以导致CSS背景不能显示。

2、边框不能撑开
如上图中,如果父级设置了CSS边框属性(css border),由于子级里使用了float属性,产生浮动,父级不能被撑开,导致边框不能随内容而被撑开。

3、margin padding设置值不能正确显示
由于浮动导致父级子级之间设置了css padding、css margin属性的值不能正确表达。特别是上下边的padding和margin不能正确显示。


【css解决浮动,清除浮动方法】

方法一:

<div class="content">
    <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:after{visibility:hidden; display:block; font-size:0; content:'\20'; clear:both; height:0;}

.cle, .clearfix, .clear_f, .cle_float{*zoom:1}


在父级加上一个class

匿名用户
2015-06-03
展开全部
清除浮动的关键是这句好不好:clear:both;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
qq4014
2015-06-03 · TA获得超过435个赞
知道小有建树答主
回答量:689
采纳率:60%
帮助的人:176万
展开全部
清除浮动时就是要用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后,第二个会显示在第一个下方。

浮动会影响自己及之后的元素,清除浮动就是清除对之后元素的影响。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式