CSS フレックスレイアウトのリストの最後の行を左揃えにする N 通りの方法 (要約)

CSS フレックスレイアウトのリストの最後の行を左揃えにする N 通りの方法 (要約)

張新旭氏の記事を引用して皆さんにシェアしたいと思います。 変更を加えたい場合は、対応する画像によって生成されたリンクをクリックして変更してください。

問題の説明

//html
<div class="コンテナ">
    <div class="list"></div>
    <div class="list"></div>
    <div class="list"></div>
    <div class="list"></div>
    <div class="list"></div>
    <div class="list"></div>
    <div class="list"></div>
</div>
//css
。容器 {
    ディスプレイ: フレックス;
    コンテンツの両端揃え: スペースの間;
    flex-wrap: ラップ;
}
.リスト{
    幅: 24%; 高さ: 100px;
    背景色: スカイブルー;
    上マージン: 15px;
}

この状況は明らかに私たちが望んでいるものとは異なります。

固定行数ソリューション

方法1: マージンを使用してギャップをシミュレートする

例えば

。容器 {
    ディスプレイ: フレックス;
    flex-wrap: ラップ;
}
.リスト{
    幅: 24%; 高さ: 100px;
    背景色: スカイブルー;
    上マージン: 15px;
}
.list:not(:n番目の子(4n)) {
    右マージン: calc(4% / 3);
}

スタイルは以下のとおりです


方法2: 最後の行の番号に基づいて余白を決定する

列の数は固定されているため、異なる数値のリストの余白値を計算して、完全な左揃えを確保できます。

たとえば、各行に 4 つの要素があり、最後の行には 3 つの要素しかない場合、最後の要素の右余白のサイズが「リストの幅 + ギャップのサイズ」であれば、最後の 3 つの要素も完全に左揃えになります。

次に、ツリー構造擬似クラス数量マッチング技術(この記事「擬似クラスリストの数をマッチングしてWeChatグループアバターCSSレイアウトを実装する技術」のレイアウト技術はこの技術の助けを借りて実装されています)の助けを借りて、最後の行にいくつの要素があるかを知ることができます。

例えば:

  • .list:last-child:nth-child(4n - 1) は、最後の行に 3 つの要素または 7 つの要素があることを示します。
  • .list:last-child:nth-child(4n - 2) は、最後の行に 2 つの要素または 6 つの要素があることを示します...

この例では、1 行に 4 つの要素があるため、次の CSS 設定を使用できます。

。容器 {
    ディスプレイ: フレックス;
    /* 両端を揃える */
    コンテンツの両端揃え: スペースの間;
    flex-wrap: ラップ;
}
.リスト{
    幅: 24%; 高さ: 100px;
    背景色: スカイブルー;
    上マージン: 15px;
}
/* 最後の行が3つの要素の場合 */
.list:最後の子:n番目の子(4n - 1) {
    右マージン: calc(24% + 4% / 3);
}
/* 最後の行が2つの要素の場合 */
.list:最後の子:n番目の子(4n - 2) {
    右マージン: calc(48% + 8% / 3);
}

提示された現象は以下のとおりである

削除してもスタイルはそのまま残ります。私はこれに感心します。

方法3: 子要素の幅が固定されていない場合

対処が難しいですが、解決策はまだあり、プログラムはますます面白くなってきています。
このとき、幅が固定されておらず、幅に基づいてマージン値を計算することができないため、上記の方法を使用するのがより困難になります。

(1)最後の項目、margin-right: auto;

。容器 {
    ディスプレイ: フレックス;
    コンテンツの両端揃え: スペースの間;
    flex-wrap: ラップ;
}
.リスト{
    背景色: スカイブルー;
    マージン: 10px;
}
/* 最後の項目 margin-right:auto */
.list:最後の子{
    右マージン: 自動;
} 

(2)疑似要素を作成し、flex:autoまたはflex:1を設定する

。容器 {
    ディスプレイ: フレックス;
    コンテンツの両端揃え: スペースの間;
    flex-wrap: ラップ;
}
.リスト{
    背景色: スカイブルー;
    マージン: 10px;
}
/* 左揃えを補助するために疑似要素を使用する*/
.コンテナ::after {
    コンテンツ: '';
    flex: auto; /* または flex: 1 */
} 

4. 行数と列数が固定されていない場合

//HTML コード:
<div class="コンテナ">
    <div class="list"></div>
    <div class="list"></div>
    <div class="list"></div>
    <div class="list"></div>
    <div class="list"></div>
    <div class="list"></div>
    <div class="list"></div>
    <i></i><i></i><i></i><i></i><i></i><i></i><i></i>//div より 1 つ少ないです!
</div>
//CSS コード:
。容器 {
    ディスプレイ: フレックス;
    コンテンツの両端揃え: スペースの間;
    flex-wrap: ラップ;
    右マージン: -10px;
}
.リスト{
    幅: 100px; 高さ: 100px;
    背景色: スカイブルー;
    マージン: 15px 10px 0 0;
}
.コンテナ > i {
    幅: 100ピクセル;
    右マージン: 10px;
} 

これで、CSS フレックス レイアウトのリストの最後の行を左揃えにする N の方法 (要約) に関するこの記事は終了です。CSS フレックス レイアウトのリストの最後の行を左揃えにする方法の詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

<<:  CentOS8 システムをベースにした Gitlab を構築するために Docker を使用する詳細なチュートリアル

>>:  MySQLの主キーと外部キーの使用と説明を簡単に説明します

推薦する

メモリの原則に関する詳細な説明: JS では変数はヒープに保存されるのか、スタックに保存されるのか?

目次1. 冷蔵庫に入りきらない象2. シャドウクローン文字列3. 実際に見た「奇妙なボール」 4. ...

Excel エクスポートは docker 環境では常に失敗する

Excel のエクスポートは、docker 環境では常に失敗します。最も直接的な原因は、中国語フォン...

innodb_autoinc_lock_mode の表現と値の選択方法についての簡単な説明

前提条件: Percona 5.6 バージョン、トランザクション分離レベルは RR mysql>...

MySQL のインデックス有効条件とインデックス無効条件の結合

目次1. ジョイントインデックスの故障の条件2. インデックス失敗の条件1. ジョイントインデックス...

MySQLワームレプリケーションの基本知識

ワームは、その名前が示すように、自ら複製し、その数は倍増、つまり指数関数的に増加します。 MySQL...

フォーム送信の更新ページはソースコード設計にジャンプしません

1. ソースコードの設計コードをコピーコードは次のとおりです。 <!DOCTYPE html ...

過去2年間のユーザーエクスペリエンス

<br />国内のウェブサイトが本格的に普及し、ユーザーエクスペリエンスに重点が置かれる...

Chromeブラウザ設定の新バージョンではクロスドメイン実装が可能

序文現在、フロントエンドは主に webpack の devServer の構成を通じてクロスドメイン...

MySQLクエリ最適化に必須の知識ポイントのまとめ

序文クエリの最適化は一夜にして達成できるものではありません。対応するツールの使い方を学び、他の人の経...

React+Ant Design開発環境をセットアップするための実装手順

基礎1. スキャフォールディングを使用してプロジェクトを作成し、開始する1.1 足場を設置する: n...

MySQL における int の最大値の詳細な説明

導入2日前に見た問題について詳細に書きます。バイトコンピューターがバイナリに基づいていることは誰もが...

QQtabBar による CSS 命名仕様 BEM の詳細な紹介

QQtabBar の BEMまず、BEMとはどういう意味でしょうか? BEM は、ブロック、要素、修...

Centos7 サーバーで jar パッケージ プロジェクトを開始する最良の方法

序文Linux 上で jar パッケージを実行する方法は誰もが知っています。なぜ別々に話したいのでし...

MySQL 8.0.18 のインストールと設定方法のグラフィック チュートリアル (Linux)

この記事では、Linux MySQL 8.0.18のインストールと設定のグラフィックチュートリアルを...

iframe テクニックを使用して訪問者 QQ 実装のアイデアとサンプル コードを取得する

今日、仕事中に、一時的に追加した友人から、Web ページを使用して訪問者の QQ を取得する方法を尋...