検索
ホームページウェブフロントエンドCSSチュートリアルより良いテーブルの設計: 追加データにポップオーバーを使用する

大規模なデータテーブルを扱う場合、利用可能な情報をすべて一度に表示すると、テーブルが膨大になって読みにくくなることがあります。その結果、二次情報を非表示にし、必要な場合にのみ詳細を明らかにするデザイン パターンを使用することが一般的です。

データ テーブルの設計は、特に大量のデータや複雑なデータを処理する場合、優れたユーザー エクスペリエンス (UX) の中心となります。次のような記事によると、テーブル デザインの UX はなぜ重要ですか?より良いデータ テーブルを設計するために、これらの隠された詳細を管理する 3 つの主な方法についてはコンセンサスがあります:

  • 展開可能な行 – テーブルの行をインラインで展開して、追加の詳細を表示します。
  • モーダル ビュー – より詳細な情報を含むモーダル ダイアログが開きます。
  • クイック ビュー (サイドバー) – 端からスライドできるサイドバーに追加の詳細が表示されます。

この記事では、これら 3 つのオプションを柔軟に設定して、テーブルのマークアップを書き直さずにオプションを切り替える方法を示します。

このために、ポップオーバーを使用します。これは、情報を特定の行に直接簡単に添付するのに最適です。


基本テーブルの設定

まず、テーブルのスタイル設定ガイドと同じマークアップとスタイルを使用します。

Designing Better Tables: Using Popovers for Extra Data

最後のセルのテキストコンテンツの後に、ポップオーバーをトリガーする簡単なボタン (アイコンは tabler からのもの) を追加しました。

<button type="button" popovertarget="p1"></button>

次に、ドキュメント内のどこかにポップオーバーを追加し、トリガーされたときに追加のコンテンツを表示します。

<div id="p1" popover>
  ... content ...   
</div>

ポップオーバーのスタイリング

ポップオーバーのスタイルには、Adam Argyle の「Steal this Popover code」のテンプレートを使用します。このテンプレートには、ポップオーバーの出現と消滅のためのスムーズなトランジションが含まれています:

.selector {
  &, &::backdrop {
    transition: 
      display .5s allow-discrete, 
      overlay .5s allow-discrete, 
      inset .5s,
      scale .5s,
      opacity .5s;
    opacity: 0;
  }

  &::backdrop {
    background: #0002;
  }

  &:popover-open {
    opacity: 1;
    &::backdrop {
      opacity: 0.5;
    }
  }

  @starting-style {
    &:popover-open,
    &:popover-open::backdrop {
      opacity: 0;
    }
  }
}

モーダルビュー

モーダル レイアウトの場合、--modal 修飾子クラスを追加してモーダルのサイズを定義し、画面の中央に配置します。

&.--modal {
  block-size: calc(100dvh - 2em);
  inline-size: calc(100dvw - 2em);
  inset-block-start: 1em;
  inset-inline: 1em;
  transform-origin: 50% 50%;

  @starting-style {
    &:popover-open{
      scale: 0;
    }
  }
}

Designing Better Tables: Using Popovers for Extra Data


クイックビュー (サイドバー)

クイックビューサイドバーを作成するには、新しい修飾子クラス --inline-start をポップオーバーに追加します。このサイドバーはビューポートの横からスライドして挿入され、スムーズなアニメーションで閉じることができます。セットアップは次のとおりです:

&.--inline-start {
  --width: clamp(220px, 33vw, 350px);
  block-size: calc(100dvh - 2em);
  inline-size: var(--width);
  inset-block-start: 1em;
  inset-inline: 1em;

  @starting-style {
    &:popover-open {
      inset-inline: calc(0px - var(--width));
    }
  }
  &[popover]:not(:popover-open) { 
    inset-inline: calc(0px - var(--ui-width));
  }
}

この設定では、ポップオーバーが左側からスライドして表示されます。 &[popover]:not(:popover-open) 行は、閉じたときにスライドして元に戻るようにします。

Designing Better Tables: Using Popovers for Extra Data

同様の調整を適用して、右側または上下からスライドイン効果を作成できます。

インライン終了 (--inline-end)

Designing Better Tables: Using Popovers for Extra Data

ブロック終了 (--block-end)

Designing Better Tables: Using Popovers for Extra Data


拡張可能な行

そして最後に、展開可能な行を見てみましょう。モーダルやサイドバーとは異なり、展開可能な行はテーブル レイアウト内に直接統合されます。従来、このアプローチには、隠された

が含まれます。 付きすべての列にまたがり、その表示を切り替える JavaScript 関数。

しかし、行をインラインで展開するために既存のポップオーバーを再利用できるでしょうか?直接ではありませんが、ポップオーバーを行のすぐ下に配置して、同様の効果を作成することで偽装できます。


まず、

にアンカー名を設定して、テーブル行の左下にポップオーバーを接続します。そして次の CSS を適用します:
<button type="button" popovertarget="p1"></button>

次に、残念ながら現在は Chrome のみ の 2 つの機能が必要です。

<div id="p1" popover>
  ... content ...   
</div>

interpolate-size プロパティを使用すると、ポップオーバーを最終的な高さまでスムーズにアニメーション化できます。一方、anchor-size を使用すると、行の幅 (または、anchor-size(height) を使用して高さ) に一致させることができます。

Designing Better Tables: Using Popovers for Extra Data

ここまでは問題ありませんが、展開された行が次の行を覆っています。

これは、展開された行内の表セルのパディングブロックエンドにポップオーバーの高さを追加することで修正できます。

Designing Better Tables: Using Popovers for Extra Data

かっこいい。錯覚が完成しました!

高さをアニメーション化するには、CSS にいくつかの追加宣言を追加します。

.selector {
  &, &::backdrop {
    transition: 
      display .5s allow-discrete, 
      overlay .5s allow-discrete, 
      inset .5s,
      scale .5s,
      opacity .5s;
    opacity: 0;
  }

  &::backdrop {
    background: #0002;
  }

  &:popover-open {
    opacity: 1;
    &::backdrop {
      opacity: 0.5;
    }
  }

  @starting-style {
    &:popover-open,
    &:popover-open::backdrop {
      opacity: 0;
    }
  }
}

パディング調整の自動化

パディングを手動で更新することを避けるために、ポップオーバーの高さに基づいてパディングを動的に更新するスクリプトを使用できます。

&.--modal {
  block-size: calc(100dvh - 2em);
  inline-size: calc(100dvw - 2em);
  inset-block-start: 1em;
  inset-inline: 1em;
  transform-origin: 50% 50%;

  @starting-style {
    &:popover-open{
      scale: 0;
    }
  }
}

このスクリプトは、ポップオーバーの切り替えイベントをリッスンし、カスタム プロパティ --row を動的に更新して、開いたときにポップオーバーの高さに一致させます。


デモ

browser.style/ui/table-expand でデモを表示できます。ここには、元のテーブル デモ スタイルもあります。

以上がより良いテーブルの設計: 追加データにポップオーバーを使用するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
WordPressブロックと要素にボックスシャドウを追加しますWordPressブロックと要素にボックスシャドウを追加しますMar 09, 2025 pm 12:53 PM

CSS Box-Shadowおよびアウトラインプロパティは、WordPress 6.1でTheme.jsonサポートを獲得しました。実際のテーマでどのように機能するか、そしてこれらのスタイルをWordPressブロックと要素に適用するために必要なオプションのいくつかの例を見てみましょう。

Smart Forms Frameworkを使用してJavaScript連絡フォームを作成するSmart Forms Frameworkを使用してJavaScript連絡フォームを作成するMar 07, 2025 am 11:33 AM

このチュートリアルでは、Smart Formsフレームワークを使用して、プロフェッショナルなJavaScriptフォームの作成を示しています(注:使用できなくなりました)。 フレームワーク自体は利用できませんが、原則とテクニックは他のフォームビルダーに関連しています。

スクリーンリーダーの分解:アクセス可能なフォームとベストプラクティススクリーンリーダーの分解:アクセス可能なフォームとベストプラクティスMar 08, 2025 am 09:45 AM

これは、フォームアクセシビリティについて行った小さなシリーズの3番目の投稿です。 2番目の投稿を逃した場合は、「ユーザーフォーカスの管理:Focus-Visible」をご覧ください。で

満足している属性を持つインラインテキストエディターを作成します満足している属性を持つインラインテキストエディターを作成しますMar 02, 2025 am 09:03 AM

インラインテキストエディターの構築は些細なものではありません。 このプロセスは、ターゲット要素を編集可能にすることから始まり、その過程で潜在的なSyntaxerrorの例外を処理します。 エディターの作成 このエディターを構築するには、コンテンツを動的に変更する必要があります

GraphQLキャッシングの使用GraphQLキャッシングの使用Mar 19, 2025 am 09:36 AM

最近GraphQLの作業を開始した場合、またはその長所と短所をレビューした場合、「GraphQLがキャッシュをサポートしていない」または

最初のカスタムSvelteトランジションを作成します最初のカスタムSvelteトランジションを作成しますMar 15, 2025 am 11:08 AM

Svelte Transition APIは、コンポーネントがカスタムSVELTE遷移を含むドキュメントを入力または離れるときにアニメーション化する方法を提供します。

5つの最高のPHPフォームビルダー(および3つの無料スクリプト)を比較する5つの最高のPHPフォームビルダー(および3つの無料スクリプト)を比較するMar 04, 2025 am 10:22 AM

この記事では、Envato Marketで入手可能なPHPフォームのビルダースクリプトを説明し、機能、柔軟性、デザインを比較します。 特定のオプションに飛び込む前に、PHPフォームのビルダーが何であるか、そしてそれを使用する理由を理解しましょう。 PHPフォーム

node.jsとexpressのMulterを使用してファイルアップロードしますnode.jsとexpressのMulterを使用してファイルアップロードしますMar 02, 2025 am 09:15 AM

このチュートリアルは、node.js、Express、およびMulterを使用してファイルアップロードシステムを構築することをガイドします。 単一および複数のファイルのアップロードをカバーし、後で検索するためにMongoDBデータベースに画像を保存することさえ示します。 まず、プロジェックをセットアップします

See all articles

ホット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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。