html - 为什么 flex 元素不缩小过去的内容大小?

标签 html css flexbox

我有 4 个 flexbox 列,一切正常,但是当我向列中添加一些文本并将其设置为大字体时,由于 flex 属性,列变得比应有的更宽。

我尝试使用 word-break: break-word 并且它有所帮助,但是当我将列的大小调整为非常小的宽度时,文本中的字母被分成多行(一个字母每行),但该列的宽度不会小于一个字母大小。

看这个video (一开始,第一列是最小的,但是当我调整窗口大小时,它是最宽的列。我只想始终尊重 flex 设置; flex 尺寸 1 : 3 : 4 : 4)

我知道,将 font-size 和 column padding 设置得更小会有所帮助...但是还有其他解决方案吗?

我不能使用overflow-x: hidden

JSFiddle

.container {
  display: flex;
  width: 100%
}
.col {
  min-height: 200px;
  padding: 30px;
  word-break: break-word
}
.col1 {
  flex: 1;
  background: orange;
  font-size: 80px
}
.col2 {
  flex: 3;
  background: yellow
}
.col3 {
  flex: 4;
  background: skyblue
}
.col4 {
  flex: 4;
  background: red
}
<div class="container">
  <div class="col col1">Lorem ipsum dolor</div>
  <div class="col col2">Lorem ipsum dolor</div>
  <div class="col col3">Lorem ipsum dolor</div>
  <div class="col col4">Lorem ipsum dolor</div>
</div>

最佳答案

flex 元素的自动最小尺寸

您遇到了 flexbox 默认设置。

flex 元素不能小于其内容沿主轴的大小。

默认是...

  • 最小宽度:自动
  • 最小高度:自动

...分别用于行方向和列方向的 flex 元素。

您可以通过将 flex 元素设置为以下方式来覆盖这些默认值:

  • 最小宽度:0
  • 最小高度:0
  • 溢出:隐藏(或任何其他值,visible 除外)

Flexbox 规范

4.5. Automatic Minimum Size of Flex Items

To provide a more reasonable default minimum size for flex items, this specification introduces a new auto value as the initial value of the min-width and min-height properties defined in CSS 2.1.

关于 auto 值...

On a flex item whose overflow is visible in the main axis, when specified on the flex item’s main-axis min-size property, specifies an automatic minimum size. It otherwise computes to 0.

换句话说:

  • min-width: automin-height: auto 默认值仅在 overflow 可见 时适用.
  • 如果 overflow 值不是visible,则 min-size 属性的值为 0
  • 因此,overflow: hidden 可以替代 min-width: 0min-height: 0

和...


你已经应用了 min-width: 0 并且元素仍然没有收缩?

嵌套 Flex 容器

如果您在 HTML 结构的多个级别上处理 flex 元素,可能需要覆盖默认的 min-width: auto/min-height: auto在更高级别的元素上。

基本上,具有 min-width: auto 的更高级别的 flex 元素可以防止缩小嵌套在 min-width: 0 下面的元素。

例子:


浏览器渲染说明

  • Chrome 与 Firefox/Edge

    至少从 2017 年开始,Chrome 似乎要么 (1) 恢复到 min-width: 0/min-height: 0 默认值,要么 ( 2) 根据神秘算法在某些情况下自动应用 0 默认值。 (这可能就是他们所说的 intervention 。)因此,许多人看到他们的布局(尤其是所需的滚动条)在 Chrome 中按预期工作,但在 Firefox/Edge 中却没有。此问题在此处有更详细的介绍:flex-shrink discrepancy between Firefox and Chrome

  • IE11

    如规范中所述,min-widthmin-height 属性的 auto 值为"new"。这意味着某些浏览器可能仍默认呈现 0 值,因为它们在值更新之前实现了 flex 布局,并且因为 0min 的初始值-widthmin-heightCSS 2.1 中。 One such browser is IE11. 其他浏览器已更新为 flexbox spec 中定义的较新的 auto 值。


修改后的演示

.container {
  display: flex;
}

.col {
  min-height: 200px;
  padding: 30px;
  word-break: break-word
}

.col1 {
  flex: 1;
  background: orange;
  font-size: 80px;
  min-width: 0;   /* NEW */
}

.col2 {
  flex: 3;
  background: yellow
}

.col3 {
  flex: 4;
  background: skyblue
}

.col4 {
  flex: 4;
  background: red
}
<div class="container">
  <div class="col col1">Lorem ipsum dolor</div>
  <div class="col col2">Lorem ipsum dolor</div>
  <div class="col col3">Lorem ipsum dolor</div>
  <div class="col col4">Lorem ipsum dolor</div>
</div>

jsFiddle

关于html - 为什么 flex 元素不缩小过去的内容大小?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53784565/

相关文章:

html - 虚拟滚动的搜索实现

css - 扩展激活下拉菜单的 "trigger area"。

javascript - Highcharts - 更改悬停点的颜色

html - 如何使两列与图像保持相同的高度?

javascript - 如何将 WordPress 帖子 ID 传递到 HTML5 本地存储

javascript - soundmanager2 html5 音频无法在 ios 上播放

javascript - 使用 jquery 查找 p 内具有特定类的图像标签

twitter-bootstrap - 让 Bootstrap 列跨越到另一行

css - Flexbox 图片不接受最大高度

css - 为什么 flex 按钮的 child 不能拉伸(stretch)到全高?