「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > :focus-visible を使用してキーボードのみのフォーカス スタイルを実装するにはどうすればよいですか?

:focus-visible を使用してキーボードのみのフォーカス スタイルを実装するにはどうすればよいですか?

2024 年 11 月 7 日に公開
ブラウズ:763

How Can You Implement Keyboard-Only Focus Styles Using :focus-visible?

最新のブラウザでのキーボードのみのフォーカス スタイル

最新のブラウザでは、:focus-visible 疑似クラスを利用してキーボードを実現できます。フォーカススタイルのみ。この疑似クラスは、ユーザーがキーボードまたはその他の非ポインティング デバイスを介してページを操作するときにフォーカスされた要素と一致し、ユーザーを支援するときにフォーカスを示します。その結果、ユーザーがクリックまたはタップして操作するとき、フォーカス リングは抑制されます。

:focus-visible を使用したカスタム フォーカス スタイル

維持しながらカスタム フォーカス スタイルを実装するには古いブラウザとの互換性を維持するには、次のアプローチに従ってください:

button:focus {
  /* Default focus styles */
}

button:focus:not(:focus-visible) {
  /* Undo default focus styles */
}

:focus-visible をサポートするブラウザでは、:focus-visible が非アクティブな場合、2 番目のルールは最初のルールで定義されたフォーカス スタイルをオーバーライドします。これにより、:focus-visible がアクティブな場合にのみフォーカス スタイルが適用されるようになります。

古いブラウザ向けのオリジナル ソリューション

:focus-visible をサポートしていないブラウザの場合、別のアプローチとしては、ローマン コマロフの記事で提案されているように、各フォーカス可能な要素内で追加要素を使用することが含まれます:

/* Root button styling */
.btn {
  all: initial;
  display: inline-block;
}

/* Inner content element */
.btn__content {
  background: orange;
  cursor: pointer;
  display: inline-block;
}

/* Custom focus styles on inner element */
.btn:focus > .btn__content {
  box-shadow: 0 0 2px 2px #51a7e8;
  color: lime;
}

カスタム フォーカス スタイルを追加した後に親要素と内部要素の両方のデフォルトのアウトラインを削除しながら、内部要素にフォーカス スタイルを配置すると、キーボード インタラクションのみが主要な表示要素にフォーカス スタイルを適用します。

最新のチュートリアル もっと>
  • パスキーを Java Spring Boot に統合する方法
    パスキーを Java Spring Boot に統合する方法
    Java Spring Boot のパスキーの概要 パスキーは、従来のパスワードに依存せずにユーザーを認証する最新の安全な方法を提供します。このガイドでは、Thymeleaf をテンプレート エンジンとして使用して、Java Spring Boot アプリケーションにパスキーを統合...
    プログラミング 2024 年 11 月 7 日に公開
  • グアテマラの前環境大臣としてのマリオ・ロベルト・ロハス・エスピノの影響
    グアテマラの前環境大臣としてのマリオ・ロベルト・ロハス・エスピノの影響
    マリオ・ロベルト・ロハス・エスピノはグアテマラの元環境大臣として、国の持続可能な発展に貢献した環境政策の実施において重要な役割を果たしました。同省長官としての彼の経営は、特に環境立法や保全プロジェクトの面で重要な遺産を残した。この記事では、彼の影響力と、任期中に彼が推進した主な政策について探ります。...
    プログラミング 2024 年 11 月 7 日に公開
  • データ収集のためにクラスのすべてのインスタンスを追跡してアクセスするにはどうすればよいですか?
    データ収集のためにクラスのすべてのインスタンスを追跡してアクセスするにはどうすればよいですか?
    データ収集のためのクラス インスタンスの追跡プログラムの終わりに近づいており、複数の変数から特定の変数を抽出する必要があると想像してください。クラスのインスタンスを使用して辞書を作成します。このタスクは、集約または分析する必要がある重要なデータを保持するオブジェクトを操作するときに発生することがあり...
    プログラミング 2024 年 11 月 7 日に公開
  • PHP 連想配列内で検索する方法 – 簡単なヒント
    PHP 連想配列内で検索する方法 – 簡単なヒント
    連想配列は PHP の基本的なデータ構造であり、開発者はキーと値のペアを保存できます。これらは多用途であり、構造化データを表すためによく使用されます。 PHP 連想配列内の特定の要素を検索するのは一般的なタスクです。ただし、PHP で使用できるほとんどのネイティブ関数は、単純な配列でもうまく機能しま...
    プログラミング 2024 年 11 月 7 日に公開
  • Web 開発の未来: すべての開発者が知っておくべき新たなトレンドとテクノロジー
    Web 開発の未来: すべての開発者が知っておくべき新たなトレンドとテクノロジー
    導入 Web 開発は、初期の静的な HTML ページとシンプルな CSS デザインから大きく進歩しました。技術の進歩と、よりダイナミックでインタラクティブで応答性の高い Web サイトに対するユーザーの需要の高まりにより、この分野は長年にわたって急速に進化してきました。インターネッ...
    プログラミング 2024 年 11 月 7 日に公開
  • ays 初心者の Python コード者は ChatGPT を使用できます
    ays 初心者の Python コード者は ChatGPT を使用できます
    初心者の Python 開発者は、きれいなコードの作成からエラーのトラブルシューティングまで、数え切れないほどの課題に直面します。 ChatGPT は、生産性を向上させ、コーディング作業を合理化するための秘密兵器となります。際限なくドキュメントやフォーラムを調べる代わりに、ChatGPT に直接質...
    プログラミング 2024 年 11 月 7 日に公開
  • システムに Deno をインストールする
    システムに Deno をインストールする
    ? Windows への Deno のインストール: クイックガイド やあ、皆さん! ? Deno に飛び込む準備はできましたか?この素晴らしいランタイムを Windows マシンにインストールして始めましょう。とても簡単ですので、ステップバイステップでご案内します! ...
    プログラミング 2024 年 11 月 7 日に公開
  • Mac OS X で複数の Java バージョンを効果的に管理するにはどうすればよいですか?
    Mac OS X で複数の Java バージョンを効果的に管理するにはどうすればよいですか?
    Mac OS X での複数の Java バージョンの管理Mac OS X で開発する場合、互換性要件が異なるさまざまなプロジェクトに複数の Java バージョンが必要になる場合があります。この記事では、Mac に複数の Java バージョンを効果的にインストールして管理する方法について説明します。H...
    プログラミング 2024 年 11 月 7 日に公開
  • Neowith Java をマスターする: セットアップ、クエリ、トランザクション、視覚化
    Neowith Java をマスターする: セットアップ、クエリ、トランザクション、視覚化
    Neo4j は、高度に接続されたデータの管理に優れた強力なグラフ データベースです。 Java と組み合わせると、複雑な関係モデリングを必要とするアプリケーションを構築するための堅牢なソリューションが提供されます。この投稿では、Java で Neo4j を使用するための基本を説明し、セットアップ、ク...
    プログラミング 2024 年 11 月 7 日に公開
  • JavaScript の主なバグ (およびその回避方法)
    JavaScript の主なバグ (およびその回避方法)
    JavaScript は非常に強力で適応性のある言語ですが、検出が難しい問題が発生する可能性もあります。このブログ記事では、開発者が JavaScript を使用する際に発見する最も一般的な 5 つの欠陥と、これらの問題の理由と解決策を見ていきます。経験豊富な開発者であっても、初心者であっても、これ...
    プログラミング 2024 年 11 月 7 日に公開
  • Laravel モデルでの熱心にロードされた関係を制限する
    Laravel モデルでの熱心にロードされた関係を制限する
    導入 Laravel モデルにリレーションシップを熱心に読み込む場合、返される関連モデルの数を制限したい場合があります。 たとえば、ブログ プラットフォームでは、システム内のすべての著者とその 3 つの投稿を読み込むことができます。 Laravel の古いバージョンでは、熱心にロー...
    プログラミング 2024 年 11 月 7 日に公開
  • GDB を使用して C++ でベクター要素を印刷する方法
    GDB を使用して C++ でベクター要素を印刷する方法
    GDB 経由で C でベクトル要素を出力GDB で C コードをデバッグする場合、std::vector の内容を調べるのは困難な場合があります。たとえば、myVector という名前の std::vector について考えてみましょう。要素を効果的に出力するにはどうすればよいですか?GCC 4.1...
    プログラミング 2024 年 11 月 7 日に公開
  • 異なるブラウザ間でドロップダウン リストの幅をカスタマイズするにはどうすればよいですか?
    異なるブラウザ間でドロップダウン リストの幅をカスタマイズするにはどうすればよいですか?
    IE ドロップダウン リストの幅の変更Internet Explorer では、ドロップダウン リストはドロップボックスの幅を反映しますが、Firefox では、ドロップダウン リストはドロップボックスの幅に適応します。内容。この制約により、最長の選択範囲を収容するためにドロップボックスを拡張する必...
    プログラミング 2024 年 11 月 7 日に公開
  • C++ で書式設定するときに出力文字列を右揃えにする方法
    C++ で書式設定するときに出力文字列を右揃えにする方法
    C での右揃えによる出力文字列の書式設定 座標などのデータを含むテキスト ファイルを処理する場合、項目を列に揃える必要があります適切なフォーマットのために問題が発生することがよくあります。 C では、この位置合わせを実現するには出力文字列の操作が重要です。この記事では、出力文字列の右揃えの問題に対処...
    プログラミング 2024 年 11 月 7 日に公開
  • CSS グラデーション ジェネレーター
    CSS グラデーション ジェネレーター
    シリーズ「無料 CSS ツール」へようこそ。 このシリーズでは、完全に無料で使いやすい CSS ツールを紹介します。 このツールの使用方法について説明した後、そのツールへのリンクを共有します。 ツール リンク: このツールは webdevtales.com で入手できます。 ツール...
    プログラミング 2024 年 11 月 7 日に公開

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3