兄弟项目在flex/grid布局中被限制了大小
P粉134288794
P粉134288794 2023-08-24 12:52:48
0
2
326
<p>我有两个兄弟元素,每个元素都包含动态内容。</p> <pre class="brush:php;toolbar:false;"><div class="flex"> <div class="sibling-1"></div> <div class="sibling-2"></div> </div></pre> <p>在某些情况下,<code>sibling-1</code>的内容会比<code>sibling-2</code>多,反之亦然。 我希望第二个元素<code>sibling-2</code>的高度始终等于第一个<code>sibling-1</code>的高度。如果<code>sibling-2</code>的高度大于<code>sibling-1</code>的高度,则会溢出<code>flex</code> div并可滚动。</p> <p>有没有办法使用Flexbox来实现这个效果?</p>
P粉134288794
P粉134288794

全部回复(2)
P粉008829791

是的,这是可能的。保留兄弟节点设置的最大高度,将其他节点的flex-basis: 0flex-grow: 1设置为,根据规范,它们会扩展到与兄弟节点相同的高度。没有绝对定位。没有在任何元素上设置高度。

main {
  display: flex;
}

section {
  display: flex;
  flex-direction: column;
  width: 7em;
  border: thin solid black;
  margin: 1em;
}

:not(.limiter)>div {
  flex-basis: 0px;
  flex-grow: 1;
  overflow-y: auto;
}
<main>
  <section>
    <div>我更长,会滚动溢出。在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中
      在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在</div>
  </section>

  <section class="limiter">
    <div>每个父节点的兄弟节点与我的高度相匹配。在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中</div>
  </section>

  <section>
    <div>我虽然较短,但仍然与高度相匹配。在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中,在流动文本中</div>
  </section>
</main>
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!