目次
一般的なスタイリングの課題に対処します
第1号:カーソル
CSSソリューション
カスタマイズカーソル
ネストされた表示コンテンツインライン
私の子供の504計画は実装されますか?
見出しとボタン
インラインスタイリング
ボーナス:インターネットエクスプローラースタイルを除く
結論
ホームページ ウェブフロントエンド CSSチュートリアル 詳細要素のスタイリングとそれらを解決する方法の2つの問題

詳細要素のスタイリングとそれらを解決する方法の2つの問題

Mar 28, 2025 am 10:42 AM

詳細要素のスタイリングとそれらを解決する方法の2つの問題

以前は、単純な拡張可能なコンテンツブロックを作成するには、JavaScriptまたは複雑なCSS回避策が必要でした。 HTMLを変更することも面倒になる可能性があります。今、<details></details>そして<summary></summary>要素(「開示ウィジェット」の形成)がこれを大幅に簡素化します。たとえば、FAQのために職場で広く使用しています。

一般的なスタイリングの課題に対処します

その間<details></details>そして<summary></summary>本質的に拡張/崩壊機能を提供しますが、最適なプレゼンテーションにはCSSが必要になる場合があります。スタイリングがなければ、2つの重要な問題が発生します。

第1号:<summary></summary>カーソル

<summary></summary>要素は、インタラクティブである間、予想されるポインターの代わりにテキスト選択カーソルにデフォルトです。

第2号:ネストされたブロック要素<summary></summary>

内部内のブロックレベルの要素(見出しなど)<summary></summary>インラインではなく、矢の下に表示されます。

CSSソリューション

これらを解決するには、これらのスタイルをCSSリセットに追加します。

詳細概要{
  カーソル:ポインター;
}

詳細概要> * {
  表示:インライン;
}
ログイン後にコピー

各問題とその解決策を詳細に調べましょう。

カスタマイズ<summary></summary>カーソル

カーソルは、意図した相互作用を視覚的に反映する必要があります。デフォルトのテキストカーソルオン<summary></summary>要素は、技術的には正しいが(テキスト選択可能)、ポインターよりも直感的ではない。

解決策は簡単です:

詳細概要{
  カーソル:ポインター;
}
ログイン後にコピー

MDN Web DocsやGitHubを含む多くの著名なWebサイトは、すでにこのスタイルを開示ウィジェットに使用しています。デフォルトのcursor: text 、概要テキストの選択性を反映している可能性がありますが、インタラクティブな要素にはポインターが一般的に望ましいです。カーソルを変更すると、視覚的な外観にのみ影響することに注意してください。選択性は変更されていません。

ネストされた表示<summary></summary>コンテンツインライン

FAQの場合、私はしばしば見出しに質問を包みます(例えば、<h3></h3> ) 内で<summary></summary>

<details><summary><h3 id="私の子供の-計画は実装されますか">私の子供の504計画は実装されますか?</h3></summary><p>はい。春と同様に、ケースマネージャーは学生に手を差し伸べます。</p></details>
ログイン後にコピー

これはいくつかの利点を提供します:

  • 一貫したスタイリング:他の見出しとの視覚的な一貫性を維持します。
  • IE/EdgeHTML互換性:サポートしていない古いブラウザにフォールバックを提供します<details></details>
  • アクセシビリティ: AIDS Assistive Technology Navigation(以下で説明するように、画面読者による解釈は異なる場合があります)。

見出しとボタン

<summary></summary>要素はボタンのように動作します(暗黙的にrole=buttonを持っています)が、ボタンとは異なり、ネストされた見出しが可能になります。これは競合を生み出します:

  • 見出しはナビゲーションを助けます。
  • ボタンは通常、ネストされた要素からセマンティクスを剥ぎ取ります。

スクリーンリーダーの互換性はここで一貫性がありません。 NVDAとナレーションは、内部の見出しを認識します<summary></summary>、しかし、顎はそうではありません。したがって、内部のスタイリング見出し中<summary></summary>可能であり、彼らの意味的な解釈は保証されていません。

インラインスタイリング

矢印が見出しの上に表示されないようにするには、内部に直接ネストされた要素のインラインスタイリングを使用します<summary></summary>

詳細概要> * {
  表示:インライン;
}
ログイン後にコピー

inline-blockではなくinlineを使用して、問題の包装を避けます。 display: flex onを使用したいと思っています<summary></summary>、これは矢を隠します。

ボーナス:インターネットエクスプローラースタイルを除く

IE以降のエッジバージョンはサポートしていないためです<details></details>、機能クエリを使用して、カスタムスタイルを適用しないでください。

 @supports not(-ms-ime-align:auto){
  詳細概要{
    カーソル:ポインター;
  }
  詳細概要> * {
    表示:インライン;
  }
  /* 他の<details>/<summary> スタイル */
}</summary></details>
ログイン後にコピー

IEはこのブロックを完全に無視します。 EdgeHTMLは-ms-ime-alignチェックのためにも無視します。非常に古いChromeおよびSafariバージョン(市場シェアが無視できる)には、機能クエリのサポートもないことに注意してください。 @supports (details)ブロックは理想的ですが、ブラウザのサポートがさらに少ないです。

結論

正しいHTML構造とこれらのCSSスタイルを使用すると、開示ウィジェットを簡単にカスタマイズできます。スタイリング中にそれを覚えておいてください<summary></summary>要素は簡単で、画面リーダーのネストされた見出しの互換性が考慮する必要があります。

以上が詳細要素のスタイリングとそれらを解決する方法の2つの問題の詳細内容です。詳細については、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チームにそれを成し遂げてくれておめでとうございます。それは大規模な努力であり、長い時間がかかったことを知っています。すべての新しいドキュメントも同様です。

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

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

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

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

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

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

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 ...

CSSを介してファーストクラスの名前アイテムを使用して子要素を選択する方法は? CSSを介してファーストクラスの名前アイテムを使用して子要素を選択する方法は? Apr 05, 2025 pm 11:24 PM

要素の数が固定されていない場合、CSSを介して指定されたクラス名の最初の子要素を選択する方法。 HTML構造を処理するとき、あなたはしばしば異なる要素に遭遇します...

See all articles