Chrome 73导致flex布局崩坏的分析与解决方法

所属分类: 网页制作 / 应用技巧 阅读数: 1396
收藏 0 赞 0 分享

现象

项目中会存在如下几种嵌套flex结构:

<style>
  /* 通用样式 */
  .card {
    width: 200px;
    height: 300px;
    margin: 20px;
    border: 1px solid #999;
  }
  .flex {
    display: flex;
    flex-direction: column;
  }
  .header {
    flex: none;
    height: 40px;
    border-bottom: 1px solid #333;
  }
  .scroll {
    overflow-y: auto;
  }
  .p {
    margin: 10px;
    height: 400px;
    background-color: rgba(0, 0, 0, 0.2);
  }  
</styl>
  
<!-- 布局一 -->
<div class="card flex">
  <div class="header">Header</div>
  <div class="flex">
    <div class="scroll">
      <div class="p"></div>
    </div>
  </div>
</div>
  
<!-- 布局二 -->
<div class="card flex">
  <div class="flex">
    <div class="header">Header</div>
    <div class="scroll" style="flex-grow:1;">
      <div class="p"></div>
    </div>
  </div>
</div>

这在Chrome 73之前的实际展示效果如下(手头的Electron——Chrome 69):

都是符合期望的结果,scroll是可以滚动的区域,然而,Chrome 73的展示效果却是:

父元素的高度都被子元素撑开了,导致scroll元素无法滚动。what? why? 纳尼?

原因

究其原因,规范有关高度的解释在这一章节,简单概括就是:

flex元素的最小大小(视主轴方向决定是高还是宽)是内部内容的大小。即,min-height/min-width默认值是“auto”。

emmm...读“规范”千遍,其义自见。当再三理解这个结论后发觉,似乎,新版Chrome的实现是符合规范的!确实,Chrome的此举改动就是为了让浏览器的flex布局行为更贴近规范。

Chrome社区的这个issue:Flexbox rendering changed between chrome 71 and 72,对上面的问题(布局二),进行了激烈的讨论,甚至最终导致了官方的回滚。

至于我们为什么后知后觉,直到73才大面积暴露该问题,下文花絮会展开解释。

不过,跟着规范走是完全的政治正确,怎么说都对!开发者只能顺应潮流去改变。

修复

其实,当看到这个现象后,我的内心并没有经历太大的波动,因为min-width曾经已经给我上过预备课了(详见下文花絮)。所以我很快就找到了解放方式。

找到最外层被撑开的元素,上文两种布局里,都是scroll的直属父元素,对其增加min-height: 0的属性即可修复异常布局。

如果min-height的行为实在无法理解的话,overflow: hidden(非visible)也能达到同样的功效。overflow平时用的比较多,相对会更有体感,如下例:

<div style="height: 200px;overflow: scroll;">
  <div style="height: 400px"></div>
</div>

当父元素设置了overflow:hidden/scroll,展示时,父元素就会隐藏子元素的溢出部分。

当然,flex布局中的overflow,它的实际作用也就是把min-height设置为0。

此外,还可以对子元素,上文示例中即scroll元素,设置height: 100%来修复。但当层级比较多时,需要将该属性一层层往下传递,不够环保。

花絮

问题是顺利修复了,下面是一些插曲~

1. Chrome 71->72->73

这个改动首发于Chrome 72,但为什么直到Chrome 73才被我们注意到?因为Chrome 72发布后,由于反响强烈,Chrome决定先回滚改动,给开发者更多的时间来适应该改动。

然而Chrome 72的发布,以及72的后续回滚发布都发生在中国春节假期期间,没什么用户反馈,对于中国开发者,例如我,完全没注意到这次预警。。。

2. min-width的学前教育

为什么说我已经被min-width提前教育过?

我实现过类似编辑器的tab:

这里就是嵌套的flex横向布局,在默认样式下,滚动区会被子元素撑开,也就是此时,我第一次领略了当初就觉得很奇怪的min-width: 0的写法。

那为什么那时就需要显式声明父元素的min-width呢?此外,这次升级所造成的误伤都是发生在纵向布局的flex上,那横向布局的flex有影响吗?

答案其实很狗血,因为Chrome对于min-width的默认值,从很早期就设置为符合规范的“auto”了。。。

参考

  1. Flexbox sets height of inside element to 0
  2. MDN min-height
  3. MDN min-width

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

更多精彩内容其他人还在看

32个典型的以分栏/网格为基础的网站

如果你正在寻找网页分栏设计的灵感,这里收集了32个典型的以分栏/网格为基础的网站。它们显示了在网页设计中分栏/网格的重要性,无论对于信息量巨大的站点还是个人博客。 1.The New York Times 2.National Post 3.Guardian 4.Times
收藏 0 赞 0 分享

理论普及——用户体验

一、概念分析1:UE用户体验 英文叫做user experience,缩写为UE, 或者UX。 当指电子商务网站的时候也被称作顾客体验(CUSTOMER EXPERIENCE). 它是指用户访问一个网站或者使用一个产品时的全部体验。他们的印象和感觉,是否成功,是否享
收藏 0 赞 0 分享

分页案例和好的实践

结构和层次降低了复杂性并提高了可读性。你的文章或站点组织的越深入,用户就越容易理解你观点和得到你想传达的信息。在网页上,这点被通过多个方式做到。 在正文头条和列举被用做逻辑上独立的数据块来呈现信息。另一种解决方法是一种叫分页的机制,它在给定文章的单一部
收藏 0 赞 0 分享

建立用户体验

也许你刚刚来到一家公司,他们希望进行一些“可用性”工作。你可能是一名UI设计师,业务分析师,或前端开发人员,一名产品经理,或者负责用户体验部门的经理或副总。你知道,如果更好地了解使用产品/软件/网站的人,就可能开发出更好的产品/软件/网站。不管怎么样
收藏 0 赞 0 分享

网页图片快速显示的方法和技巧

1. Use .gifs rather than .jpgs. GIFs are smaller in size when compared to JPGs. 1.用.gifs格式保存图片,最好不要用.jpgs格式。因为前者的尺寸比后者小。 2.Use 'Height
收藏 0 赞 0 分享

推荐60种分页案例和好的实践

结构和层次降低了复杂性并提高了可读性。你的文章或站点组织的越深入,用户就越容易理解你观点和得到你想传达的信息。在网页上,这点被通过多个方式做到。 在正文头条和列举被用做逻辑上独立的数据块来呈现信息。另一种解决方法是一种叫分页的机制,它在给定文章的单一部
收藏 0 赞 0 分享

全面的网站评估方案

有时会被问到“看看XXX网站如何?”之类的问题。 谈到评估,通常都是指产品级的网站,如果模式很新,了解需要花一定时间。于是,很多人又问“那么你仅从UI/UE的角度看看呢?”首先我们得达成共识,一切花里胡哨都在为功能服务,如果功
收藏 0 赞 0 分享

网页的栅格设计思考

原文地址:http://andymao.com/andy/post/82.html 网页设计中的脏、乱、差,是我们在设计过程中常会遇到的问题。通常"脏"是由对色彩使用不当所产生的,而色彩使用不当产生的不好效果也分为:"花、灰",花哨、
收藏 0 赞 0 分享

设计理论设计中的层次感

原文:http://andymao.com/andy/post/80.html 这段时间我一直在说设计需要有层次感,这种层次感可能有很多类型,比如色彩的层次感,或是元素的层次感。当一个设计缺乏层次感的时候页面所表现出来的无非是两种可能,一种是单调,一种是花哨。在设计中我们常
收藏 0 赞 0 分享

网页心得:网页色彩的搭配

网页的色彩是树立网站形象的关键之一,色彩搭配却是网友们感到头疼的问题。网页的背景,文字,图标,边框,超链接...,应该采用什么样的色彩,应该搭配什么色彩才能最好的表达出预想的内涵呢?这里谈一些心得,希望对你有所启发。 首先我们先来了解一些色彩的基本知识:
收藏 0 赞 0 分享
查看更多