長文ドキュメント
# 序論
序論の内容
〜については次の脚注を参照ください。 [1]
# 本論
本論の内容
〜については次の脚注を参照ください。 [2]
# 結論
結論の内容
〜については次の脚注を参照ください。 [3]
Digital Publishing WAI-ARIA Module 1.1では、長文ドキュメント内で容易にナビゲートするための仕様や方法が定義されている。
長文ドキュメントの典型であるマニュアルなどはコンテンツの上部に目次があり、そこから各見出しにジャンプできる。単純にidとhrefを使うだけでなく、アクセシビリティの観点も考慮する必要がある。
目次はrole=“doc-toc”を使って作成する。
Digital Publishing WAI-ARIA Module 1.1のサンプルコードには role="directory"
が使われているが、ARIA 1.2で非推奨になっているので使わない。
Warning: The
directory
role was deprecated in ARIA 1.2
ARIA: directory role - ARIA | MDN
<nav role="doc-toc">
<h2>Contents</h2>
<ol>
<li><a href="#chapter1">序論</a></li>
<li><a href="#chapter2">本論</a></li>
<li><a href="#chapter3">結論</a></li>
...
</ol>
</nav>
セクションはrole=“doc-chapter”を使って作成する。またidを指定して目次のリンクと紐づける。
「見出しに#
アイコンをつけクリックしたらその見出しにジャンプ」というのもよく見かける。Digital Publishing WAI-ARIA Module 1.1で必須、または強く推奨されているわけではないがリンクを共有するときなどに便利だろう。
<section role="doc-chapter" id="chapter1">
<h2>
序論
<a href="#chapter1" aria-label="序論へのリンク">#</a>
</h2>
<p>...</p>
</section>
<section role="doc-chapter" id="chapter2">
<h2>
本論
<a href="#chapter2" aria-label="本論へのリンク">#</a>
</h2>
<p>...</p>
</section>
<section role="doc-chapter" id="chapter3">
<h2>
結論
<a href="#chapter3" aria-label="結論へのリンク">#</a>
</h2>
<p>...</p>
</section>
本文中に脚注を配置する場合はrole=“doc-noteref”とrole=“doc-footnote”を使う。
またバックリンク(脚注から本文に戻るためのリンク)の追加も推奨されている。バックリンクはrole=“doc-backlink”を使う。
※サンプルコードではnote6
のように手動でidを振っているが文書内で一意にする必要があるため、自動採番するほうが安全かもしれない。
<!-- 本文中 -->
<p>
〜については次の脚注を参照ください。
<a
role="doc-noteref"
href="#footnote6"
aria-label="脚注へのリンク"
id="note6"
>[6]</a>
</p>
<aside id="footnote6" role="doc-footnote">
<a
role="doc-backlink"
href="#note6"
>[6]</a>
脚注について
</aside>
セクションやコンテンツの最後にまとめて脚注を配置する場合は、代わりにrole=“doc-endnotes”を使う。
<section role="doc-endnotes">
<h2>脚注</h2>
<ol>
<li id="footnote1">
<a
role="doc-backlink"
href="#note1"
>[1]</a>
<p>脚注...</p>
</li>
<li id="footnote2">
<a
role="doc-backlink"
href="#note2"
>[2]</a>
<p>脚注...</p>
</li>
</ol>
</section>
# 序論
序論の内容
〜については次の脚注を参照ください。 [1]
# 本論
本論の内容
〜については次の脚注を参照ください。 [2]
# 結論
結論の内容
〜については次の脚注を参照ください。 [3]