overflow-x:hidden对其内position:absolute的影响

在写一个Header组件的时候,添加了其中一行样式:

.header{
	overflow-x:hidden;
...
}

随后添加一个下拉列表,很自然地添加了:

.downlist{
	position:absolute;
	top:100%;
	left:0px;
    ...
}

然后发现,原本应该显示在.header以外的.downlist,却显示在.header内,并成了overflow-y:scroll;的效果,demo如下。

实验了下,

以div元素F为容器,其子元素C设置position:absolute,结论:

1.将overflow-x:hidden;去掉后,position:absolute可以正常使用。

2.给F添加overflow-x:hidden;后,如果需要将其子元素C通过position:absolute设置位置,left | top | right |bottom 依然可以使用,且依旧可以设置其位置。但是设定子元素的位置后,如果子元素的一部分超出F,或子元素整个在F外,则会从内部把F撑开。也就是说,F的外部边界(高宽)不变,但是内部自动添加overflow-y:scroll效果。

3.此时如果显示给子元素C添加overflow-y:auto || scroll || visible,相当于overflow-y:scroll 的效果。 如果添加的是overflow:hidden;则元素F不再滚动,元素C的超出F的部分也不会显示。

*overflow-x:hidden;只是影响了元素的BFC,这个情况与flex布局无关。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值