単一選択折りたたみメニュー機能を実現するCSS

単一選択折りたたみメニュー機能を実現するCSS

前回の「最もシンプルなスイッチを実現するCSS」のように、HTML5とCSS3でほとんどの機能をすでに実装できるため、絶対に必要な場合を除いてフロントエンドUIフレームワークを導入しないでください。

dca0a8cfcb26d3cd87aed4ceeceee3b4.png

しかし、多くの人の考え方は依然として Web2.0 時代にとどまっており、さまざまなライブラリを使用して UI を作成し、Web ページが肥大化しています。今日は、JavaScript を必要とせず、純粋な CSS を使用して単一選択の折りたたみメニューを実装する方法を説明します。アコーディオンはタブに似ており、論理的にはどちらも単一選択パネルですが、アコーディオンは通常垂直に積み重ねられるのに対し、タブは水平に配置される点が異なります。

873ecdccbd4a9eda8905fa3dda8a95f3.gif

タブ:

6af435a8d5daf3680c52d09d86cf2254.gif

選択肢は 1 つだけなので、<input type="radio">ラジオ ボタンを使用して実装できます。まず、これらのラジオ ボタン グループの親要素は <form> を使用します。これは、<form> がボタン グループの変更を監視できるだけでなく、RadioNodeList リストを直接取得して name 属性を通じて値を変更できるため、非常に便利であり、他の CSS セレクターを設定する必要がないためです。したがって、この折りたたみメニューの HTML は次のようになります。

<フォームid="フォーム">
    <input type="radio" name="collapse">
    <div></div>
 
    <input type="radio" name="collapse">
    <div></div>

    <input type="radio" name="collapse">
    <div></div>
</フォーム>

<form> の ID を設定して、window[id] から直接見つけられるようにします。各 <radio> の name 属性は一貫している必要があり、form[name] を介してラジオ グループを取得します。form[name].value は現在選択されているボタンの値で、折りたたみボタンのタイトルです。各 <radio> の後には、展開されたメニューのコンテンツである <div> が続きます。ただし、デフォルトの <radio> は次のようになります。

3734ce405520be5e763445ce517388d4.gif

または、まず appearance: none を使用して上記のようにデフォルトのスタイルを無効にし、次にボタンの左側の名前として ::before を使用し (value 属性を読み取ります)、右側の小さな矢印として ::after (文字 > と v)、折りたたまれた状態を示すために :checked 属性を使用します。

入力[type="radio"] {       
      カーソル: ポインタ;
      外観: なし;
      表示: ブロック;
}
 
 
入力[type="radio"]::before {
      コンテンツ: attr(値);
}
 
 
入力[type="radio"]::after {       
      フロート: 右;
      コンテンツ:">";
}
 
 
入力[type="radio"]:checked::after {
      内容: "v";
}

<div> の場合はデフォルトで非表示になっており、選択した <radio> の後ろにある <div> のみが表示されます。折りたたみアニメーションについては、ニーズによって異なります。私にとっては、アニメーションなしの方が爽快です。

入力[type="radio"] + div {
      表示: なし;
}
 
 
入力[type="radio"]:チェック済み + div {
      表示: ブロック;
}

上記は基本的なレイアウトですが、少しスタイルを追加すると次のようになります。

192e7d623a0ddedcc4811c5fab7db066.png

ただし、<radio> の特性上、メニューを反転することはできません。メニューを展開した後は、別のメニュー項目をクリックしてのみ折りたたむことができます。もちろん、これで問題ありません。メニュー選択の反転機能を実装する必要がある場合は、最後に展開したメニュー項目を記録し、クリック イベントが発生するたびに、繰り返しクリックかどうかを判断する必要があります。

// すべての<radio>に対して
ラジオ.onclick = () => {
  if (window.radio === radio) {
    入力がチェックされている = false;
    ウィンドウ.radio = null;
  } そうでない場合は、window.radio = radio;
};

これは、単一選択折りたたみメニューの逆選択機能を実装します。

翻訳元

ちなみに、画像内の乱雑なテキストは、元のテキストがスクランブルされた結果です (プライバシー上の理由により)。次のコードを使用して文字列をスクランブルできます。

文字列.split('').sort(() => Math.random() - 0.5).join('')

CSSでシングルチョイス折りたたみメニュー機能を実装する方法についての記事はこれで終わりです。CSSシングルチョイス折りたたみメニューの関連コンテンツについては、123WORDPRESS.COMの過去の記事を検索するか、以下の関連記事を引き続き閲覧してください。今後とも123WORDPRESS.COMをよろしくお願いいたします。

<<:  表に斜めヘッダー効果を出す5つの方法

>>:  Linuxシステムにおけるプロセス管理の詳細な説明

推薦する

MySQL でよく使われる連結文のまとめ

はじめに: MySQL では、CONCAT() 関数を使用して複数の文字列を 1 つの文字列に連結し...

Mybatis mysqlの削除操作では、最初のデータメソッドのみを削除できます。

バグ図のように、削除文とパラメータをデータベースにコピーして実行し、2つのデータを削除しようとしたの...

Vue3 Vue イベント処理ガイド

目次1. 基本的なイベント処理2. 親コンポーネントにカスタムイベントを送信するマウス修飾子4. キ...

MySQLデータ行と行オーバーフローのメカニズムの詳細な説明

1. 行の形式は何ですか? MySQL の行形式の設定は次のように表示されます。 実際、MySQL ...

Docker データ ストレージ tmpfs マウントの詳細な説明

この記事を読む前に、ボリュームとバインドマウントの基本を理解しておいてください。詳細については、次の...

Javascriptの基礎を学ぶための10の重要な質問

目次1. Javascript とは何ですか? 2. DOMとは何か3. JSコードの実行方法4. ...

jQueryは検証コード送信のコントロールボタンを無効にする機能を実装します

必要な効果: 確認コードを送信するためにクリックした後、ボタンは無効になり、5 秒後に無効解除されま...

CSS スキル コレクション - 古典の中の古典

リンク上の点線のボックスを削除しますコードをコピーコードは次のとおりです。 a:アクティブ、a:フォ...

jQuery における Ajax の関連知識ポイントのまとめ

序文JavaScriptを学ぶ学生は、 AJAX (非同期JavaScriptとxml) 変換は非同...

Tomcatのデフォルトプログラム公開パスの使用と変更についての説明

tomcat7 のデフォルトのプログラム公開パスは tomcat/webapps/ROOT/ です。...

トップ 10 Js 画像処理ライブラリ

目次導入1. 異食症2. レナ3. コンプレッサー4. ファブリック5. ぼかす6. 画像を結合する...

CentOS 6.8 での Hadoop 3.1.1 完全分散インストール ガイド (推奨)

上記:このドキュメントは、3 台の仮想マシンが相互に ping を実行できること、ファイアウォールが...

ウェブページの画像最適化ツールと使用方法のヒントの共有

ウェブページの基本要素として、画像はページの読み込み速度に影響を与える重要な要素の 1 つです。画像...

MySQL の 2 種類の一時テーブルの使用方法の詳細な説明

外部一時テーブルCREATE TEMPORARY TABLE によって作成された一時テーブルは、外部...

JPQLに基づく純粋なSQL文方式の詳細な説明

JPQL は Java Persistence Query Language の略です。 Java ...