html - 如何使用 CSS flexbox 设置固定宽度的列

标签 html css flexbox

我希望红色框在并排 View 中时只有 25 em 宽 - 我试图通过在此媒体查询中设置 CSS 来实现此目的:

@media all and (min-width: 811px) {...}

到:

.flexbox .red {
  width: 25em;
}

但是当我这样做时,会发生这种情况:

enter image description here代码笔:http://codepen.io/anon/pen/RPNpaP .

知道我做错了什么吗?

最佳答案

您应该使用 flexflex-basis 属性而不是 width。在 MDN 上阅读更多内容.

.flexbox .red {
  flex: 0 0 25em;
}

flex CSS 属性是一个速记属性,指定 flex 元素改变其尺寸以填充可用空间的能力。它包含:

flex-grow: 0;     /* do not grow   - initial value: 0 */
flex-shrink: 0;   /* do not shrink - initial value: 1 */
flex-basis: 25em; /* width/height  - initial value: auto */

一个简单的演示展示了如何将第一列设置为 50px 固定宽度。

.flexbox {
  display: flex;
}
.red {
  background: red;
  flex: 0 0 50px;
}
.green {
  background: green;
  flex: 1;
}
.blue {
  background: blue;
  flex: 1;
}
<div class="flexbox">
  <div class="red">1</div>
  <div class="green">2</div>
  <div class="blue">3</div>
</div>


参见 updated codepen基于您的代码。

关于html - 如何使用 CSS flexbox 设置固定宽度的列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29885284/

相关文章:

html - 将 <span> 相对于容器 div 居中,将另一个 span 与其左侧的右对齐文本对齐

javascript - 根据innerText更改HTML表格单元格值

css - 将特定断点及以下的元素水平居中

javascript - 如何使用纯 css、HTML 和 javascript 自动网格布局?

css - 索环主题与组件上的自定义 CSS 混合

html - CSS:使 Flexbox 布局静态化

javascript - 使用 Javascript 下载 Html5 canvas 元素作为具有文件扩展名的图像

css - Safari:flexbox 和最小高度

css - 带有 anchor 链接的垂直居中 svg 图像

html - 站点未响应媒体查询