html - flex column wrap时,如何让第二列不占满第一列的高度?

标签 html css reactjs flexbox

假设我有一个包含 15 个元素的 flex 容器。如果我希望该列换行,以便第一列中有 10 个元素(例如)而第二列中有 5 个元素,则第二列中的每个元素的高度应仅与第一列中的元素相同。换句话说,这 5 个元素不应该占用与第一列相同的空间——间距看起来很奇怪。

有没有办法让列表中的最后一项只出现在整个容器高度的中间点?

我想要什么:

Item      Item 
Item      Item
Item      Item
Item      Item 
Item      Item
Item      
Item       
Item      
Item  

发生了什么:

Item      Item 
Item      
Item      Item
Item       
Item      Item
Item      
Item      Item 
Item      
Item      Item

React/styled-components 代码:

  <DailyValuesContainer flexDirection="column" wrap="wrap" justify="space-between">
      <DailyValueItem>
        <DvQuantity>0g</DvQuantity><DailyValue>Saturated Fat</DailyValue>
      </DailyValueItem>
      <DailyValueItem>
        <DvQuantity>0g</DvQuantity><DailyValue>Trans Fat</DailyValue>
      </DailyValueItem>
      <DailyValueItem>
        <DvQuantity>0mg</DvQuantity><DailyValue>Cholesterol</DailyValue>
      </DailyValueItem>
      <DailyValueItem>
        <DvQuantity>7mg</DvQuantity><DailyValue>Sodium</DailyValue>
      </DailyValueItem>
      <DailyValueItem>
        <DvQuantity>11g</DvQuantity><DailyValue>Dietary Fibers</DailyValue>
      </DailyValueItem>
      <DailyValueItem>
        <DvQuantity>8g</DvQuantity><DailyValue>Sugar</DailyValue>
      </DailyValueItem>
      <DailyValueItem>
        <DvQuantity>1%</DvQuantity><DailyValue>Vitamin A</DailyValue>
      </DailyValueItem>
      <DailyValueItem>
        <DvQuantity>4%</DvQuantity><DailyValue>Vitamin C</DailyValue>
      </DailyValueItem>
      <DailyValueItem>
        <DvQuantity>11%</DvQuantity><DailyValue>Calcium</DailyValue>
      </DailyValueItem>
      <DailyValueItem>
        <DvQuantity>34%</DvQuantity><DailyValue>Iron</DailyValue>
      </DailyValueItem>
    </DailyValuesContainer>


 const DailyValuesContainer = styled(FlexContainer)`
  max-height: 170px;

const DailyValueItem = styled(FlexContainer)`
  margin-bottom: 12px;
  height: 12px;
`

const DailyValue = styled.p`
  font-weight: 400;
  font-size: 13px;
  line-height: 15px;
  color: ${colors.primary500};
`
const DvQuantity = styled(DailyValue)`
  width: 45px;
`

最佳答案

你期待这样吗:

#main {
  width: 200px;
  height: 600px;
  border: 1px solid #c3c3c3;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
}

#main div {
  width: inherit;
  height: 60px;
}
<div id="main">
  <div style="background-color:grey;">item 1 </div>

  <div style="background-color:lightblue;">item 2 </div>

  <div style="background-color:khaki;">item 3 </div>

  <div style="background-color:pink;">item 4 </div>

  <div style="background-color:lightgrey;">item 5</div>

  <div style="background-color:grey;">item 6 </div>

  <div style="background-color:lightblue;">item 7 </div>

  <div style="background-color:khaki;">item 8</div>

  <div style="background-color:pink;">item 9</div>

  <div style="background-color:red;">item 10</div>


  <div style="background-color:grey;">item 1 </div>

  <div style="background-color:lightblue;">item 2 </div>

  <div style="background-color:khaki;">item 3 </div>

  <div style="background-color:pink;">item 4 </div>

  <div style="background-color:lightgrey;">item 5</div>
</div>

试试这段代码:

<DailyValuesContainer>
    <DailyValueItem>
      <DvQuantity>0g</DvQuantity><DailyValue>Saturated Fat</DailyValue>
    </DailyValueItem>
    <DailyValueItem>
      <DvQuantity>0g</DvQuantity><DailyValue>Trans Fat</DailyValue>
    </DailyValueItem>
    <DailyValueItem>
      <DvQuantity>0mg</DvQuantity><DailyValue>Cholesterol</DailyValue>
    </DailyValueItem>
    <DailyValueItem>
      <DvQuantity>7mg</DvQuantity><DailyValue>Sodium</DailyValue>
    </DailyValueItem>
    <DailyValueItem>
      <DvQuantity>11g</DvQuantity><DailyValue>Dietary Fibers</DailyValue>
    </DailyValueItem>
    <DailyValueItem>
      <DvQuantity>8g</DvQuantity><DailyValue>Sugar</DailyValue>
    </DailyValueItem>
    <DailyValueItem>
      <DvQuantity>1%</DvQuantity><DailyValue>Vitamin A</DailyValue>
    </DailyValueItem>
    <DailyValueItem>
      <DvQuantity>4%</DvQuantity><DailyValue>Vitamin C</DailyValue>
    </DailyValueItem>
    <DailyValueItem>
      <DvQuantity>11%</DvQuantity><DailyValue>Calcium</DailyValue>
    </DailyValueItem>
    <DailyValueItem>
      <DvQuantity>34%</DvQuantity><DailyValue>Iron</DailyValue>
    </DailyValueItem>
</DailyValuesContainer>


const DailyValuesContainer = styled(FlexContainer)'
width: 200px;
height: 600px;
border: 1px solid #c3c3c3;
display: -webkit-flex;
-webkit-flex-wrap: wrap;
display: flex;
flex-wrap: wrap;
flex-direction: column;
 ';    

const DailyValueItem = styled(FlexContainer)'
width: inherit;
height: 60px;
';    

const DailyValue = styled.p'
font-weight: 400;
font-size: 13px;
line-height: 15px;
color: ${colors.primary500};
';

const DvQuantity = styled(DailyValue)'
width: 45px;
';

关于html - flex column wrap时,如何让第二列不占满第一列的高度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58045512/

相关文章:

html - header 拉伸(stretch)太远

ReactJS:放置在子组件上时 onClick 处理程序不会触发

javascript - 第三方 slider 添加具有 'class' 等属性的动态元素。我正在使用 react

css - 选择中的 A​​ntd 自动换行

javascript - jQuery 淡入/淡出替换文本删除链接

javascript - Canvas 文本和图像模糊

html - CSS 图像每次都在文本下方

javascript - 无法将元素的设置值设置为 "innerHTML"

jquery - 想在 jquery 中用文本框在新行中显示选择框

css - 2个 float 容器在同一条线上