ホームページ ウェブフロントエンド CSSチュートリアル 選択リスト項目をCSSグリッドと一緒にグループ化します

選択リスト項目をCSSグリッドと一緒にグループ化します

Mar 07, 2025 pm 04:36 PM

Grouping Selection List Items Together With CSS Grid

選択したリスト項目をCSSグリッドを介して巧みにグループ化して、ユーザーエクスペリエンスを向上させます! 選択されたアイテムグループは、選択されたアイテムと選択されていないアイテムをすばやく区別するのに役立つ一般的な設計戦略です。たとえば、To Doリストでは、完成したアイテムが上向きに移動し、ユーザーが残りのタスクに集中しやすくなります。

同様のグループUIを設計します。選択したアイテムの単純な再配置とは異なり、CSSグリッドを使用して、選択したアイテムを水平方向にレイアウトして、選択されていないアイテムと選択されていないアイテムをさらに区別します。

2つの方法を検討します。 1つは、選択したアイテムがグリッドコンテナの境界を超えない状況に適しているため、安定したレイアウトを使用します。 auto-fill span2つのメソッドのHTMLコードは同じです:

コードは、順序付けされていないリスト(
ログイン後にコピー
ログイン後にコピー
    <li> <li>
)で構成されています。 CSSグリッド属性がプロジェクトのレイアウトを決定するため、要素を追加する必要はありません。暗黙的な

要素を使用してラップを使用して、追加のラッピングを避けますが、通常、明示的なタグは支援技術によってよりサポートされています。 <ul></ul> <label></label>

メソッド1:

auto-fillを使用します リスト項目を含む

要素は、グリッドコンテナにするために
ul {
  width: 250px;
  display: grid;
  gap: 14px 10px;
  grid-template-columns: repeat(auto-fill, 40px);
  justify-content: center;
  /* ...其他样式... */
}
ログイン後にコピー
に設定されています。グリッドの行と列の間に14pxと10pxのギャップを設定します。グリッドコンテンツは、中心に水平に整列されています。

プロパティは、グリッド内の列のサイズを指定します。初期状態では、すべてのアイテムが単一の列にあります。アイテムが選択されると、それらは最初の行に移動し、選択した各アイテムが列を占有します。キーは値にあります。 <ul></ul> display: gridgrid-template-columns値は、auto-fill関数の繰り返しの数に使用されます。列が繰り返され、各列のトラックサイズが

(例で40px)に与えられ、グリッドコンテナの境界に適応できるようにします。

リスト項目の初期ステータスが単一の列であることを確認するには:auto-fill repeat() repeat()アイテムが選択されている場合(

要素が選択されています)、

セレクターを使用してください:

li {
  width: inherit;
  grid-column: 1;
  /* 等同于:grid-column-start: 1; grid-column-end: auto; */
  /* ...其他样式... */
}
ログイン後にコピー

これにより、選択したアイテムがリストの上部にグループ化され、水平に配置されます。 <input> :has(:checked)

メソッド2:キーワード
li {
  width: inherit;
  grid-column: 1;
  /* ...其他样式... */
  &:has(:checked) {
    grid-area: 1;
    /* 等同于:grid-row-start: 1; grid-column-start: auto; grid-row-end: auto; grid-column-end: auto; */
    width: 40px;
    /* ...其他样式... */
  }
  /* ...其他样式... */
}
ログイン後にコピー

を使用します

このメソッドは

属性を必要としません。新しいスタイルは次のとおりです span

グリッドアイテムの整列を支援します。更新

スタイル:grid-template-columns <ul></ul>

各アイテムは最初の列に配置されますが、現在は6つの列トラックにも及びます(6つのアイテムがあるため)。これにより、グリッドに複数の列が表示されると、選択したアイテムが選択されたアイテムの下にある後に選択されていないアイテムが選択されていないことが保証されます。
ul {
  width: 250px;
  display: grid;
  gap: 14px 10px;
  justify-content: center;
  justify-items: center;
  /* ...其他样式... */
}
ログイン後にコピー
宣言は、アイテムを中心に保ちます。

justify-items: center <li>選択したアイテムの幅が増加し、アイテムが選択されたアイテムが選択されたときに、選択したUIのレイアウトを表示します。

li {
  width: inherit;
  grid-column: 1 / span 6;
  /* 等同于:grid-column-start: 1; grid-column-end: span 6; */
  /* ...其他样式... */
}
ログイン後にコピー

Orderを選択justify-items: center

選択されていないアイテムの順序は、ソース順序と同じままです。ユーザーの選択と一致するために画面の順序が必要な場合、アイテムが選択されたときに増分注文値が動的に割り当てられます。

ログイン後にコピー
ログイン後にコピー
    <li> <li>

概要

CSSグリッドは、多くの構成なしで両方の方法を非常に柔軟にします。 auto-fillを使用してどちらの軸(行または列)にアイテムを配置することにより、選択したアイテムがコンテナにオーバーフローしない限り、選択したアイテムを同じ容器内の選択されていないアイテムのレイアウトに影響を与えることなく、選択したアイテムをグリッドコンテナに簡単にグループ化できます。

アイテムがコンテナにオーバーフローしている場合、

メソッドを使用すると、特定の軸上の選択されたアイテムの長さに関係なく、レイアウトを維持するのに役立ちます。 UIのいくつかの設計的な代替品には、選択したアイテムをリストの最後までグループ化するか、水平構造と垂直構造を交換することが含まれます。 span

以上が選択リスト項目をCSSグリッドと一緒にグループ化しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Vue 3 Vue 3 Apr 02, 2025 pm 06:32 PM

それは&#039; Vueチームにそれを成し遂げてくれておめでとうございます。それは大規模な努力であり、長い時間がかかったことを知っています。すべての新しいドキュメントも同様です。

Redwood.jsと動物相を使用してイーサリアムアプリを構築します Redwood.jsと動物相を使用してイーサリアムアプリを構築します Mar 28, 2025 am 09:18 AM

最近のビットコインの価格が20k $ $ USDを超えており、最近30Kを破ったので、イーサリアムを作成するために深く掘り下げる価値があると思いました

ブラウザから有効なCSSプロパティ値を取得できますか? ブラウザから有効なCSSプロパティ値を取得できますか? Apr 02, 2025 pm 06:17 PM

私はこの非常に正当な質問で誰かに書いてもらいました。 Leaは、ブラウザから有効なCSSプロパティ自体を取得する方法についてブログを書いています。それはこのようなものです。

粘着性のあるポジショニングとサスのダッシュを備えた積み重ねられたカード 粘着性のあるポジショニングとサスのダッシュを備えた積み重ねられたカード Apr 03, 2025 am 10:30 AM

先日、Corey Ginnivanのウェブサイトから、この特に素敵なビットを見つけました。そこでは、スクロール中にカードのコレクションが互いに積み重ねられていました。

CI/CDで少し CI/CDで少し Apr 02, 2025 pm 06:21 PM

「ウェブサイト」は「モバイルアプリ」よりも適していると言いますが、Max Lynchからのこのフレーミングが好きです。

WordPressブロックエディターでのマークダウンとローカリゼーションを使用します WordPressブロックエディターでのマークダウンとローカリゼーションを使用します Apr 02, 2025 am 04:27 AM

WordPressエディターでユーザーに直接ドキュメントを表示する必要がある場合、それを行うための最良の方法は何ですか?

レスポンシブデザインのブラウザを比較します レスポンシブデザインのブラウザを比較します Apr 02, 2025 pm 06:25 PM

これらのデスクトップアプリがいくつかあり、目標があなたのサイトをさまざまな次元ですべて同時に表示しています。たとえば、書くことができます

フレックスレイアウト内の紫色のスラッシュ領域が誤って「オーバーフロー空間」と見なされるのはなぜですか? フレックスレイアウト内の紫色のスラッシュ領域が誤って「オーバーフロー空間」と見なされるのはなぜですか? Apr 05, 2025 pm 05:51 PM

フレックスレイアウトの紫色のスラッシュ領域に関する質問フレックスレイアウトを使用すると、開発者ツールなどの混乱する現象に遭遇する可能性があります(D ...

See all articles