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

来源:http://stackoverflow.com/questions/28636832/firefox-overflow-y-not-working-with-nested-flexbox

使用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布局相当好使,但是这些浏览器厂商老毛病又犯了,都想自己搞一套规范,好烦。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,796评论 1 92
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,335评论 0 11
  • H5移动端知识点总结 阅读目录 移动开发基本知识点 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇阅读 4,623评论 0 26
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    wzhiq896阅读 1,803评论 0 2
  • 此片为友人摄于内蒙古。 湖山初醒 云舒云卷湖初昼,水影流光点点鸥。 惺忪远山忙装扮,妆容一...
    BRS阅读 232评论 5 2