为什么调html中margin没有变化,css margin 不管用

本文介绍了当CSS margin属性不起作用时的原因及解决方法,主要针对由块级格式上下文(BFC)引起的margin折叠现象,提供了多种实用解决方案。

4534ac42861761d456b47caa544126f7.png

css margin 不管用

设置了margin却没有效果,这是因为产生了块级格式上下文(BFC),下面就来说说解决方法吧。

BFC的生成

满足下列css声明之一的元素便会生成BFC

● 根元素

● float的值不为none

● overflow的值不为visible

● display的值为inline-block、table-cell、table-caption

● position的值为absolute或fixed

BFC的约束规则

浏览器对BFC这块区域的约束规则如下:

生成BFC元素的子元素会一个接一个的放置,垂直方向上他们的起点是一个包含块的顶部,两个相邻子元素之间的垂直距离取决于元素的margin特性。在BFC中相邻的块级元素外边距会折叠。生成BFC元素的子元素中,每一个子元素左外边距与包含块的左边界相接触,(对于从右到左的格式化,右外边距接触右边界),即使浮动元素也是如此(尽管子元素的内容区域会由浮动而压缩),除非这个子元素也创建了一个新的BFC(如它自身也是一个浮动元素)

.A { height: 50px; margin-top: 50px; width: 50px; background-color: red; }

.B { height: 200px; margin-top: 100px; width: 200px; background-color: green; }

.C { height: 50px; margin-top: 50px; width: 50px; background-color: blue; }

A

C

8fcbd90db630e6de75e282b00b48d971.png

解决方法:

1. 设置元素为overflow:hidden

2. 在浮动元素下面放一个属性clear:both的元素

3. 为浮动元素设置 ::after::after {

content: ""; //设置内容为空

height: 0; //高度为0

line-height: 0; //行高为0

display: block; //将文本转为块级元素

visibility: hidden; //将元素隐藏

clear: both //清除浮动

}

更多CSS相关技术文章,请访问CSS3答疑栏目进行学习!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值