検索

CSSを使用したアクセス可能な脚注

キーテイクアウト

  • CSSカウンターを使用して、脚注の番号付けを自動化することができ、ドキュメントの変更が行われたときに手動の変更の必要性を減らすことができます。フッター内の脚注の順序は、テキストの参照の順序と一致する必要があります。
  • 脚注をスクリーンリーダーにアクセスできるようにするために、フッターにタイトルを追加して、脚注の参照を説明できます。 「Aria-DescribedBy」属性を使用して、このタイトルへの参照をリンクできます。
  • css ':: after' pseudo-elementを使用して、各脚注リファレンスのカウンターを表示できます。 「:ターゲット」の擬似クラスは、参照されたときに脚注を強調するために使用できます。
  • 脚注を完全にアクセスしやすくするには、コンテンツに戻るリンクを追加できます。これには、コンテンツ内の各リファレンスに一意のID属性を追加することが含まれます。これは、フッター内の各リストアイテムにリンクを追加することでリンクできます。 「Aria-Label」属性を使用して、これらのリンクを説明できます。
  • 先日、CSSカウンターで遊んでいて、脚注に対処するためにそれらを使用することを考えました。この問題について驚くほど長いエントリを持っている盗作によると、脚注は次のとおりです。
  • […]ページの下部に配置されたメモ。彼らは参照を引用したり、その上のテキストの指定された部分についてコメントしたりします。

著者が情報を追加したり、コンテンツの中央でそれを行ったり、括弧を使用したりせずに参照を引用したいときに、論文でそれらをよく見ることがよくあります。通常、脚注は、ドキュメント内の脚注の位置に従って数字で表され、その後、ドキュメントの下部に同じ数字が存在し、追加のコンテンツを追加します。

ウェブ上の脚注の問題は、維持するのが苦痛になる可能性があることです。同じドキュメントで頻繁に作業し、セクションの順序を変更し、途中で参照を追加する場合、既存のすべての脚注を再番号を変更する必要があるのは退屈かもしれません。たとえば、ドキュメント内の脚注への既存の参照が3つあり、別の脚注を追加する場合は、他のすべての前に発生するコンテンツに追加する場合は、それらすべてを変更する必要があります。素晴らしいことではありません…

CSSカウンターを使用して、この全体をはるかに簡単にすることができます。番号を手で維持する必要がなく、自動的に実行できる場合はどうなりますか?私たちが注意を払わなければならない唯一のことは、フッター内の実際のメモの順序は、テキストの参照の外観の順序を尊重するということです。

サンプルドキュメントの作成

開始できるようにサンプルドキュメントを作成しましょう。

私たちの例は軽量です。要素にコンテンツがいくつかあります。これには、記事ののメモにマッピングされたドキュメント内のIDを指すリンク()が含まれています。 >

いくつかのスタイルがある場合、次のように見えるかもしれません:

CSSを使用したアクセス可能な脚注

アクセス可能にする

実際にカウンターの問題に到達する前に、スクリーンリーダーがマークアップに完全にアクセスできるようにする必要があります。最初にやりたいことは、説明または脚注の参照として機能するフッターにタイトルを追加することです。このタイトルをCSSで非表示にして、視覚的に表示されないようにします。

<span><span><span><article>></article></span>
</span>  <span><span><span><h1 id="gt">></h1></span>CSS-Powered Footnotes<span><span></span>></span>
</span>
  <span><span><span><p>></p></span>Maintaining <span><span><a> href<span>="#footnotes"</span>></a></span>footnotes<span><span></span></span></span></span></span></span></span>
> manually can be a pain. By using href="#css">CSS> href="#css-counters">counters> to add the numbered references in the text and an ordered list to display the actual footnotes in the footer, it becomes extremely easy.>
>
    >
  • id="footnotes">
  • Footnotes are notes placed at the bottom of a page. They
    cite references or comment on a designated part of the text above it.>
  • id="css">
  • Cascading Style Sheets>
  • id="css-counters">
  • CSS counters are, in essence, variables maintained by
    CSS whose values may be incremented by CSS rules to track how many times they're used.> > > >次に、Aria-DescribedBy属性を使用して、このタイトルですべての参照を説明したいと思います。

    今、スクリーンリーダーユーザーは、リンクが脚注への参照であることを理解します。
    <span><span><span><footer>></footer></span>
    </span>  <span><span><span><h2 id="id-span-footnote-label-span-gt"> id<span>="footnote-label"</span>></h2></span>Footnotes<span><span></span>></span>
    </span>  <span><span><span><ol>></ol></span>
    </span>    ...
      <span><span><span></span>></span>
    </span><span><span><span></span>></span></span></span></span></span>

    参照を追加

    私はあなたが何を考えているか知っています:

    彼はCSSカウンターがあると言った。 CSSカウンターはどこにありますか?

    心配しないでください、私の友人、彼らは来ています。 私たちがやろうとしていることは、脚注ラベルに設定されたARIAと説明された属性を備えたドキュメント内のすべてのリンクのカウンターをインクリメントすることです。次に、Pseudo-Elementの後の::を使用してカウンターを表示します。そこから、CSSスタイルを適用することがすべてです

    今、次のように見えます:

    <span><span><span><p>></p></span>Maintaining <span><span><a> aria-describedby<span>="footnote-label"</span> href<span>="#footnotes"</span>></a></span>footnotes<span><span></span>></span> 
    </span>manually can be a pain. By using <span><span><span><a> aria-describedby<span>="footnote-label"</span> href<span>="#css"</span>></a></span>CSS<span><span></span>></span> 
    </span><span><span><span><a> aria-describedby<span>="footnote-label"</span> href<span>="#css-counters"</span>></a></span>counters<span><span></span>></span> to add the 
    </span>numbered references in the text and an ordered list to display the actual footnotes 
    in the footer, it becomes extremely easy.<span><span><span></span>></span></span></span></span></span></span>

    かなりいいね最後のタッチとして、参照から脚注に向かうとき、フッターのメモを強調表示したいので、実際に参照されているメモが何であるかを確認します。 CSSを使用したアクセス可能な脚注

    少し生ですので、お気軽にカスタマイズしてください。私はハイライトのために純粋な黄色が好きだと言わなければなりません - それはとても本物に見えます:

    <span>/**
    </span><span> * Initialiazing a `footnotes` counter on the wrapper
    </span><span> */
    </span><span>article {
    </span>  <span>counter-reset: footnotes;
    </span><span>}
    </span>
    <span>/**
    </span><span> * Inline footnotes references
    </span><span> * 1. Increment the counter at each new reference
    </span><span> * 2. Reset link styles to make it appear like regular text
    </span><span> */
    </span><span>a<span><span>[aria-describedby="footnote-label"]</span></span> {
    </span>  <span>counter-increment: footnotes; /* 1 */
    </span>  <span>text-decoration: none; /* 2 */
    </span>  <span>color: inherit; /* 2 */
    </span>  <span>cursor: default; /* 2 */
    </span>  <span>outline: none; /* 2 */
    </span><span>}
    </span>
    <span>/**
    </span><span> * Actual numbered references
    </span><span> * 1. Display the current state of the counter (e.g. `[1]`)
    </span><span> * 2. Align text as superscript
    </span><span> * 3. Make the number smaller (since it's superscript)
    </span><span> * 4. Slightly offset the number from the text
    </span><span> * 5. Reset link styles on the number to show it's usable
    </span><span> */
    </span><span>a<span><span>[aria-describedby="footnote-label"]</span>::after</span> {
    </span>  <span>content: '[' counter(footnotes) ']'; /* 1 */
    </span>  <span>vertical-align: super; /* 2 */
    </span>  <span>font-size: 0.5em; /* 3 */
    </span>  <span>margin-left: 2px; /* 4 */
    </span>  <span>color: blue; /* 5 */
    </span>  <span>text-decoration: underline; /* 5 */
    </span>  <span>cursor: pointer; /* 5 */
    </span><span>}
    </span>
    <span>/**
    </span><span> * Resetting the default focused styles on the number
    </span><span> */
    </span><span>a<span><span>[aria-describedby="footnote-label"]</span>:focus::after</span> {
    </span>  <span>outline: thin dotted;
    </span>  <span>outline-offset: 2px;
    </span><span>}</span>

    バックリンクを提供する

    CSSを使用したアクセス可能な脚注私たちのデモには、完全にアクセスできるように最終的な要素が1つ必要です。考えてみてください:参照に焦点を合わせ、フッターの関連するメモに向かい、それを読んでから…何もしません。あなたが去った場所に戻る方法が必要です!

    これらのリンクを提供することはそれほど難しくありません。コンテンツ内の各参照に一意のID属性を追加して、リンクできるようにするだけです。私はシンプルに行って、彼らが参照するIDを取ることにしました、そして単にそれにrefを追加することにしました:

    フッターの各リストアイテムには、追加した関連のIDに向かう独自のリンクがあります。リンクのコンテンツは、

    バックリンク

    unicodeアイコン(↩)であり、「コンテンツに戻る」の値を持つaria-label属性を備えています。

    <span>footer <span>:target</span> {
    </span>  <span>background: yellow;
    </span><span>}</span>
    CSSのリンクをターゲットにするために、Aria-Label属性に頼ることができます。

    ここに最終的なデモがどのように見えるかがあります:

    CodepenのSitePoint(@SitePoint)によるCSSを使用したペンアクセス可能な脚注を参照してください。

    最終的な考え

    CSSの数行といくつかのARIA属性以外は何もありませんでしたが、アクセス可能でJavaScriptを必要としないCSSを搭載した脚注を作成することができました。それはどれほどクールですか?

    トピックについては、Heydon Pickeringのインテリジェントセレクターを使用したセマンティックCSSを強くお勧めします。また、ページのアクセシビリティを確認するには、GaëlPoupardのa11y.cssを必ずチェックしてください。 このデモでのアクセシビリティに関する彼の貴重な助けをしてくれたHeydon Pickeringに感謝します。

    CSSのアクセス可能な脚注に関するよくある質問(FAQ)

    Webコンテンツで脚注を使用することの重要性は何ですか?

    ​​脚注は、Webコンテンツの読みやすさと信頼性を高める上で重要な役割を果たします。メインコンテンツのフローを混乱させることなく、追加情報、説明、または参照を提供します。これらは、詳細な説明や情報源が必要な学術、研究、または技術コンテンツで特に役立ちます。脚注を使用することで、読者は裁量でトピックをより深く掘り下げて、コンテンツをよりユーザーフレンドリーでアクセス可能にすることを選択できます。 CSSを使用した脚注には、いくつかのステップが含まれます。まず、適切なタグを使用してHTMLの脚注をマークアップする必要があります。次に、CSSを使用して、脚注をスタイリングおよび配置できます。 CSSを使用すると、ページ上のフォントサイズ、色、位置など、脚注の外観を制御できます。 CSSを使用して脚注からメインテキストへのリンクを作成して、読者がコンテンツをナビゲートしやすくすることもできます。 、CSSを使用して動的な脚注を作成できます。これは、特定の単語やフレーズの上にホバリングするなど、ユーザーの相互作用に基づいて、脚注を表示または消滅させることができることを意味します。これは、CSS擬似クラスと遷移を使用して実現できます。ただし、そのような動的な脚注が、支援技術を使用しているユーザーを含むすべてのユーザーがまだアクセスできるようにすることが重要です。それらがメインテキストと明確に区​​別できることを確認することが重要であり、ナビゲートしやすく、有用な情報を提供することが重要です。これは、脚注に異なるフォントサイズまたは色を使用し、メインテキストにリンクを提供し、脚注が関連性があり簡潔であることを確認することで実現できます。さらに、脚注をさまざまな支援技術でテストして、本当にアクセスできるようにすることが重要です。

    CSSを使用して脚注をスタイリングするにはどうすればよいですか?

    CSSは、脚注のスタイルに使用できる幅広いプロパティを提供します。たとえば、「フォントサイズ」プロパティを使用して、脚注テキストのサイズ、「色」プロパティを変更して色を変更すること、およびページ上の位置を制御する「位置」プロパティを調整できます。また、CSSを使用して脚注の周りに境界線を作成したり、背景色を追加したり、他のスタイルの効果を適用したりすることもできます。脚注がスクリーンリーダーにアクセスできることを確認してください。セマンティックHTMLマークアップを使用して、各脚注の開始と終了を明確に示す必要があります。 Ariaの役割とプロパティを使用して、脚注に関する追加情報を提供して、技術を支援することもできます。さらに、画面リーダーユーザーがコンテンツを簡単にナビゲートできるように、各脚注からメインテキストにリンクを提供することが重要です。 >

    はい、CSSを使用して、異なるデバイスで応答する脚注を作成できます。これは、メディアクエリを使用して、画面サイズに基づいて脚注のスタイルと位置を調整することで実現できます。これにより、脚注がデスクトップコンピューターから携帯電話まで、すべてのデバイスで読みやすくナビゲートできるようになります。脚注を作成する場合、それらを長すぎるか複雑にすること、メインテキストへのリンクを提供するのではなく、支援技術でテストすることはありません。また、脚注を明確で簡潔な執筆の代替として使用することを避けることも重要です。脚注はメインテキストを補う必要があり、それに置き換えないでください。

    CSSを使用して脚注のホバー効果を作成するにはどうすればよいですか? ':Hover' pseudoクラスを使用します。これにより、ユーザーがマウスでhoversしたときに脚注のスタイルを変更できます。たとえば、脚注の背景色を変更したり、ポップアップボックスに表示したりできます。ただし、このホバー効果にキーボードユーザーとアシスタントテクノロジーのユーザーがアクセスできるようにすることが重要です。

    CSSを使用して、異なる言語で脚注を作成できますか?さまざまな言語で脚注を作成するCSS。これは、「lang()」pseudoクラスを使用して、言語に基づいて脚注にさまざまなスタイルを適用することで実現できます。これにより、多様な視聴者に応じて、言語に関係なく、すべてのユーザーがコンテンツにアクセスできるようになります。

    以上がCSSを使用したアクセス可能な脚注の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
    CSSインクルージョン:プロジェクトに適した方法を選択しますCSSインクルージョン:プロジェクトに適した方法を選択しますMay 16, 2025 am 12:02 AM

    bestmethod forincludingcsssdependsonprojectsized complexity:1)forlargerprojects、useexternalcssssssssssssssavesainabyandperformance.2)

    これは発生することは想定されていません。不可能をトラブルシューティングしますこれは発生することは想定されていません。不可能をトラブルシューティングしますMay 15, 2025 am 10:32 AM

    あなたが考えたことのない他の何かであることが判明したそれらの不可能な問題の1つをトラブルシューティングすることがどのように見えるか。

    @KeyFrames対CSSトランジション:違いは何ですか?@KeyFrames対CSSトランジション:違いは何ですか?May 14, 2025 am 12:01 AM

    @keyframesandcsstransitionsdifferincomplexity:@keyframesallowsfordeTailedAnimationのシーケンス、whilecsstransitionshandlesimplestatechanges.usecsstransitionsは、ButtonColorChanges、および@keyframesforintricateanimationslikerotatingingspinnnersを使用します。

    静的サイトコンテンツ管理にページCMSを使用します静的サイトコンテンツ管理にページCMSを使用しますMay 13, 2025 am 09:24 AM

    私は知っています、私は知っています:たくさんのコンテンツ管理システムオプションが利用可能であり、私はいくつかテストしましたが、実際にはY&#039;知っているものはありませんでしたか?奇妙な価格設定モデル、困難なカスタマイズ、一部は全体になることさえあります&

    HTMLのCSSファイルをリンクするための究極のガイドHTMLのCSSファイルをリンクするための究極のガイドMay 13, 2025 am 12:02 AM

    CSSファイルをHTMLにリンクすることは、HTMLの一部で要素を使用することで実現できます。 1)タグを使用して、ローカルCSSファイルをリンクします。 2)複数のタグを追加することにより、複数のCSSファイルを実装できます。 3)外部CSSファイルは、そのような絶対URLリンクを使用します。 4)ファイルパスとCSSファイルの読み込み順序の正しい使用を確認し、パフォーマンスを最適化すると、CSSプリプロセッサを使用してファイルをマージできます。

    CSS Flexbox vsグリッド:包括的なレビューCSS Flexbox vsグリッド:包括的なレビューMay 12, 2025 am 12:01 AM

    FlexBoxまたはグリッドの選択は、レイアウト要件によって異なります。1)FlexBoxは、ナビゲーションバーなどの1次元レイアウトに適しています。 2)グリッドは、雑誌のレイアウトなどの2次元レイアウトに適しています。この2つは、レイアウト効果を改善するためにプロジェクトで使用できます。

    CSSファイルを含める方法:メソッドとベストプラクティスCSSファイルを含める方法:メソッドとベストプラクティスMay 11, 2025 am 12:02 AM

    CSSファイルを含める最良の方法は、タグを使用してHTMLパーツに外部CSSファイルを導入することです。 1.タグを使用して、外部CSSファイルを導入します。 2。小さな調整のために、インラインCSSを使用できますが、注意して使用する必要があります。 3.大規模プロジェクトでは、@Importを介して他のCSSファイルをインポートするために、SASS以下などのCSSプリプロセッサを使用できます。 4。パフォーマンスのために、CSSファイルをマージし、CDNを使用し、CSSNANOなどのツールを使用して圧縮する必要があります。

    FlexBox対グリッド:両方を学ぶべきですか?FlexBox対グリッド:両方を学ぶべきですか?May 10, 2025 am 12:01 AM

    はい、Youはrelearnbothlexboxandgrid.1)FlexBoxisidealforone-Dimensional、FlexiblleayoutslikenavigationMenus.2)Gridexcelsintwo-digsignssuchasmagazinelayouts.3)Bothenhanceslaysutibulivedibulisunivedivition、floctonsulururを

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

    Video Face Swap

    Video Face Swap

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

    ホットツール

    Safe Exam Browser

    Safe Exam Browser

    Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

    SublimeText3 英語版

    SublimeText3 英語版

    推奨: Win バージョン、コードプロンプトをサポート!

    MinGW - Minimalist GNU for Windows

    MinGW - Minimalist GNU for Windows

    このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

    mPDF

    mPDF

    mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール