margin-top小bug

1.当父元素嵌套子元素垂直排排列时,他们的margin-top就会取其中一个margin-top的最大值,导致父元素的整体下移

理想图理想很美满,but现实现实很残酷大哭

<style>
		*{margin: 0;padding: 0;}
		#box1{width: 100px;height: 100px;background: gray;}
		#box1 .box2{width: 20px;height: 20px;background: pink;margin-top: 30px;}
	</style>
	<body>
		<div id="box1">
			<div class="box2"></div>
		</div>
	</body>

这是上图的代码,可以看出在id名为box1内的子元素box2设置了margin-top属性,但是却依然整体一起下滑了。好吧,这种同甘共苦的精神我很欣赏,但是为了我的效果,你们还是gg吧。

有三种解决办法:

1.给父元素加一个边框;

2.给父元素加overflow:hidden;属性;

3.取消margin-top父元素适用padding-bottom


综上所述,再见了~再见

开个玩笑...在三种方法中第二种最为好用,不用多余添加border,也可以按照自己的想法适用margin。

2.当两个兄弟元素垂直排列时,上面的一个元素的margin-bottom与下一个元素的margin-top取值为两者中最大值。


额.....敢情这是W3C的语法标准,没什么好说的~goodnight

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值