css - flexbox:如果图像较高则居中对齐,如果文本较高则 flex-start

标签 css flexbox

想象一个站点组件,左侧是文本,右侧是图像,它随页面宽度缩放。图像不缩放,但文本宽度是流动的。文本内容可以改变。我正在使用 flexbox 来实现这一点。

例子:

<main>
  <div class="text">
    <h1>Lorem ipsum</h1>
    <p>Dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.</p>
  </div>
  <div class="image">
    <img src="https://placeimg.com/300/200/any">
  </div>
</main>
main {
  display: flex;
  align-items: center;
/*   align-items: flex-start; */
  width: 50%;
  margin: 0 auto;
  background: lightgray;
  padding: 2em;
}

h1, p {
  margin: 0;
}

h1 + p {
  margin-top: 1em;
}

https://codepen.io/marcvangend/pen/xModrN 查看此示例.

在较小的屏幕宽度上,当文本较高时,我希望文本和图像在顶部对齐。 align-items: flex-start; 会这样做。在更宽的屏幕上,当图像高度高于文本时,我希望两个元素都垂直居中,如 align-items: center; 那样。

是否有一种干净的方法(无 JS)可以根据哪个元素更高在两种对齐方式之间自动切换?

最佳答案

在写这个问题时,我想到了解决方案:-)

幸运的是,这很简单,只需添加:

.image {
  margin-bottom: auto;
}

关于css - flexbox:如果图像较高则居中对齐,如果文本较高则 flex-start,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54824223/

相关文章:

html - 无论内容长度如何,均等宽度的 flex 元素

html - Flexbox 在 IE 10 中不工作

html - 使 flex 元素的 child 不会超出 flex 元素

html - CSS:td 上的双边框显示为单边框

html - 基础 zurb 中的切换顶部栏问题

html - css 网格元素定位

java - 可以在 gwt 中设置 native 滚动条的样式,而不定义自定义滚动条并且不使用 ScrollPanel 或 CustomScrollPanel?

javascript - if 有条件使用 jquery 停止崩溃 ('hide' ) 函数 - Bootstrap 3

html - 四列布局未调整大小以适应屏幕尺寸

css - Flexbox 容器内的图像(垂直对齐),如果父级更改大小(使用 Flexbox),则不会更改大小