ホームページ >ウェブフロントエンド >CSSチュートリアル >8 つの要素を動的にサイズ変更するときに、フレックスボックスを使用して 4 つの要素を 2 行強制的に配置するにはどうすればよいですか?

8 つの要素を動的にサイズ変更するときに、フレックスボックスを使用して 4 つの要素を 2 行強制的に配置するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-12-29 08:07:10334ブラウズ

How to Force Two Rows of Four Elements Each Using Flexbox When Dynamically Resizing Eight Elements?

Flexbox レイアウト: 1 行あたり 4 要素

Flexbox を使用してページ上の 8 つの要素のサイズを動的に変更する場合、強制的に分割する方法2 行 (1 行あたり 4 つ) に分割しますか?

次のコード スニペットがあるとします:

<div class="parent-wrapper">
  <div class="parent">
    <div class="child"></div>
    <div class="child"></div>
    <div class="child"></div>
    <div class="child"></div>
    <div class="child"></div>
    <div class="child"></div>
    <div class="child"></div>
    <div class="child"></div>
  </div>
</div>
.parent-wrapper {
  height: 100%;
  width: 100%;
  border: 1px solid black;
}

.parent {
  display: flex;
  font-size: 0;
  flex-wrap: wrap;
  margin: -10px 0 0 -10px;
}

.child {
  display: inline-block;
  background: blue;
  margin: 10px 0 0 10px;
  flex-grow: 1;
  height: 100px;
}

解決策:

問題は flex-wrap にあります。flex でラップします。要素をラップできるようにするcontainer。ただし、flex-grow: 1 では要素を無制限に拡張できるため、スペースが不足すると要素のラップに失敗します。

解決策は、要素の幅を定義して強制的に折り返すことです。

.parent {
  display: flex;
  flex-wrap: wrap;
}

.child {
  flex: 1 0 21%; /* 展开说明如下 */
  margin: 5px;
  height: 100px;
  background-color: blue;
}

flex プロパティの最初の値 (この例では 1) は、スペースをすべての要素に均等に分配します。要素の 2 番目の値 (0) は最小幅を 0 に設定し、3 番目の値 (21%) は要素の最大幅を使用可能な幅の 21% に定義します。このように設定すると、最大幅に達する前に要素が折り返され、1 行あたり 4 要素のレイアウトが作成されます。

以上が8 つの要素を動的にサイズ変更するときに、フレックスボックスを使用して 4 つの要素を 2 行強制的に配置するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。