8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

使容器在包装时收缩以适应子元素

Certes 2月前

56 0

我正在尝试弄清楚 flexbox 如何在以下情况下工作(应该如何工作?...): .holder { width: 500px; background: lightgray; display: flex; flex-direction: row; justify-content:

我正在尝试弄清楚 flexbox 在以下情况下如何工作(应该如何工作?...):

.holder {
  width: 500px;
  background: lightgray;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  flex-wrap: nowrap;
}
.v2 {
  width: 320px;
}
.child {
  display: inline-block;
  border: 1px solid black;
  padding: 30px 0px;
  text-align: center;
}
<div class="holder">
  <div class="child">At a glance</div>
  <div class="child">After coverage ends</div>
  <div class="child">Forms &amp; documents</div>
</div>
<br>
<br>
<div class="holder v2">
  <div class="child">At a glance</div>
  <div class="child">After coverage ends</div>
  <div class="child">Forms &amp; documents</div>
</div>
<br>
<br>
<div class="holder v2">
  <div class="child">At a
    <br>glance</div>
  <div class="child">After coverage
    <br>ends</div>
  <div class="child">Forms &amp;
    <br>documents</div>
</div>

JSFiddle 在这里

问题是,当有足够的空间容纳元素时,我会得到一个紧密贴合的子元素,并且它们之间的间距均匀。(第一个,顶部 div 块)

但是,当没有足够的空间并且子元素内的文本开始换行时,一切都会朝着奇怪的方向发展 - 子元素不再紧密贴合,尽管换行之后,弹性子元素周围有足够的空间,但由于不再合适,周围的空间实际上也没有机会发挥作用(第二个 div 块)

但是,如果我在自动换行符出现的地方添加手动换行符,那么所有内容都会按照“应该”的方式布局……(底部,第三个块)

我希望的是让孩子们紧紧地呆在他们的盒子(黑色边框)里,剩下的空间会均匀分布在他们之间,而我不需要添加手动换行符(在我的情况下这不是一个选项)

这可能吗?

帖子版权声明 1、本帖标题:使容器在包装时收缩以适应子元素
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由Certes在本站《css》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 仔细看看 我修改过的 Fiddle

    • .holder width max-width (在 .v 类中)
    • 修改 .holder wrap 及其 space-around 子项
    • 为清晰起见, 添加了 2 个 .v
    • 删除了 <br>'s
    • 最重要的是添加 flex: 0 0 .child

    Flexbox 几乎总是需要 max-width 设置的,这比 更灵活 width 。根据您需要 .child ren 的行为方式,修改 flex-grow flex-shr以k in flex: 0 0 满足您的需求。( 的结果 flex: 1 0 看起来也不错)

    ...不需要 Javascript...

    Codrops Flexbox 参考 对于理解灵活框布局非常有用。

返回
作者最近主题: