Firefox下flex元素overflow失效的原因和修复

使用flex布局时,有些需要滚动显示全部内容的元素在Firefox下却不能滚动,其原因在于overflow失效。
解决方法:
给该元素添加min-height: 0或者min-width: 0,取决于你的滚动方向,如果无效,尝试给其父元素添加该style,以此类推。
原因:
在firefox下,flex元素默认将其最小尺寸设置为其子元素的尺寸,这意味着父元素永远能显示全部子元素,即使这样导致整个页面超过了屏幕。这还overflow个鬼嘛!。因此我们需要覆盖默认的最小尺寸。
firefox的这一设定可以参见MDN:
https://developer.mozilla.org/zh-CN/docs/Web/CSS/CSS_Flexible_Box_Layout/Using_CSS_flexible_boxes

为了确保弹性项目有合理的默认最小尺寸,使用 min-width:auto 与 min-height:auto。对于弹性项目,属性值 auto 使项目的最小宽/高在计算中不会小于其内容的实际宽/高,这样可以保证项目渲染得足够大以容纳其内容。更多细节请参考 min-width 与 min-height 

然而这一条内容已经在英文文档被删除,中文也加了删除线,估计是准备改了,不过目前Firefox并未更新掉这一问题。
chrome等其它主流浏览器貌似没有类似问题,因为它们并未实现这个规则。
flex布局相当好使,但是这些浏览器厂商老毛病又犯了,都想自己搞一套规范,好烦。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值