1. ホーム
  2. css

[解決済み] 最後のフレックスアイテムをコンテナの最後に配置する

2022-04-21 18:29:15

質問

この質問は、flexboxを含むcss3フルサポートのブラウザに関するものです。

私はフレックスコンテナにいくつかのアイテムを入れています。それらはすべてflex-startにジャストフィットしていますが、私は 最後の .end の項目がフレックスエンドにジャストフィットするようにしたい。HTMLを修正せず、絶対配置に頼らずにこれを行う良い方法はないでしょうか?

.container {
  display: flex;
  flex-direction: column;
  outline: 1px solid green;
  min-height: 400px;
  width: 100px;
  justify-content: flex-start;
}
p {
  height: 50px;
  background-color: blue;
  margin: 5px;
}
<div class="container">
  <p></p>
  <p></p>
  <p></p>
  <p class="end"></p>
</div>

解決方法は?

<ブロッククオート

Flexible Box Layout Module - 8.1. 自動マージンによる整列

フレックスアイテムのオートマージンは、ブロックフローのオートマージンと非常によく似た効果があります。

  • フレックスベースとフレックスレングスの計算時に、オートマージンは0として扱われます。

  • によるアライメントの前に justify-contentalign-self の場合、正の自由空間はその次元の自動余白に分配される。

したがって margin-top: auto を使用して、他の要素と最後の要素との間のスペースを分散させることができます。

これにより、最後の要素が一番下に配置されます。

p:last-of-type {
  margin-top: auto;
}

.container {
  display: flex;
  flex-direction: column;
  border: 1px solid #000;
  min-height: 200px;
  width: 100px;
}
p {
  height: 30px;
  background-color: blue;
  margin: 5px;
}
p:last-of-type {
  margin-top: auto;
}
<div class="container">
  <p></p>
  <p></p>
  <p></p>
</div>


また、同様に margin-left: auto または margin-right: auto を指定すると、水平方向に同じアライメントになります。

p:last-of-type {
  margin-left: auto;
}

.container {
  display: flex;
  width: 100%;
  border: 1px solid #000;
}
p {
  height: 50px;
  width: 50px;
  background-color: blue;
  margin: 5px;
}
p:last-of-type {
  margin-left: auto;
}
<div class="container">
  <p></p>
  <p></p>
  <p></p>
  <p></p>
</div>