★HTML Living Standard リファレンス

当サイトのリンクからサインアップしても、利用者の方に追加料金はかかりませんが、私たちが紹介手数料を受け取る場合があります。

<dialog> …… ダイアログボックスを表す
Internet Explorer
Microsoft Edge
Google Chrome
Safari
Firefox
Opera
広告



<dialog>タグは、ダイアログボックスを表す際に使用します。

dialog要素は、アプリケーションがユーザーと対話するための情報を表します。
具体的には、アプリケーションが何らかのタスクを実行するための小さなウィンドウ(ダイアログボックス)です。

ダイアログボックスは、
ユーザーにメッセージを伝えたり、
ユーザーに入力などの操作を促したりする目的で表示されます。

開いたダイアログボックスは、
ユーザーがメッセージを読み終えたり入力などの作業を完了すると、
アプリケーションによって自動的に閉じられるか、ユーザーが手動で閉じることができます。

■属性

open属性
ダイアログボックスが表示されているかどうかを指定します。

open属性はダイアログボックスを開いた状態にする

dialog要素にopen属性を指定すると、ダイアログボックスが開いた状態になります。
この状態は、dialog要素がアクティブでユーザーがdialog要素と対話できることを示します。
open属性が指定されていないdialog要素は、ユーザーに表示されません。

子孫要素のいずれかにautofocus属性を指定する

ダイアログでユーザーに入力などの操作を促す場合、
すぐに操作することが予想される子孫要素には、autofocus属性を指定する必要があります。
そのような子孫要素がない場合、dialog要素自体にautofocus属性を指定する必要があります。
ユーザーの期待に一致するように、どの要素にautofocus属性を指定するべきか検討します。

■使用例

以下のサンプルは、製品管理ウェブアプリケーションという想定です。
dialog要素にopen属性を指定して、最初からダイアログが開くようにしています。

開いたダイアログでは、製品名の入力欄にautofocus属性を指定して、まずは製品名から入力するようユーザーに促しています。

HTMLソース

<dialog open>
  <label>製品名 <input type="text" autofocus></label>
  <label>摘要 <input type="text"></label>
</dialog>

↓↓↓

ブラウザ上の表示




ダイアログでスクロールが発生しないように配慮する

ダイアログのテキスト量が多い場合など、
内容がオーバーフローしてスクロールが発生することがあります。
例えば、ユーザーがフォントサイズをズーム設定にしていると、
制作者が意図していなくてもスクロールが発生する可能性があります。

一般的に、ユーザーはスクロールが必要なダイアログを好みません。
そのため、できるだけダイアログでスクロールが発生しないように配慮します。

■使用例

以下のサンプルは、dialog要素を使用して利用規約をダイアログボックスで表示しています。
この際、スクロールが発生しにくいように、ダイアログボックスの高さをCSSで指定しています。

尚、div要素にautofocus属性を指定しているのは、もしスクロールが必要になった場合などに、
すぐに操作することが予想される子孫要素だからです。

HTMLソース

<dialog open style="height: 60vh;">
  <div style="overflow: auto; height: 50vh;" autofocus>
    <h4>利用規約</h4>
    <p>ユーザーは、自己の責任において本サービスを利用するものとします。</p>
    <p>ユーザーは、本サービスのユーザーIDおよびパスワードを適切に管理するものとします。</p>
    <p>ユーザーIDおよびパスワードを第三者に譲渡または貸与することはできません。</p>
    <p>本サービスの利用によって生じた損害について、当社は一切の責任を負わないものとします。</p>
  </div>
  <form method="dialog">
    <button type="submit" value="agree">同意する</button>
    <button type="submit" value="disagree">同意しない</button>
  </form>
</dialog>

↓↓↓

ブラウザ上の表示

利用規約

ユーザーは、自己の責任において本サービスを利用するものとします。

ユーザーは、本サービスのユーザーIDおよびパスワードを適切に管理するものとします。

ユーザーIDおよびパスワードを第三者に譲渡または貸与することはできません。

本サービスの利用によって生じた損害について、当社は一切の責任を負わないものとします。



「ダイアログを閉じる」と「ダイアログを非表示にする」

「ダイアログを閉じる」と「ダイアログを非表示にする」は異なります。
ダイアログを閉じると、戻り値が返されイベントが発生し、他のダイアログのページのブロックが解除されます。

一方、ダイアログの非表示は、視覚的なプロパティの問題です。
ダイアログの非表示は、hidden属性を使用するか、open属性を削除することで実行されます。

「ダイアログを開く」と「ダイアログを表示する」

「ダイアログを開く」と「ダイアログを表示する」は異なります。
ダイアログを開くことのなかには、そのダイアログを作成して表示することが含まれています。

一方、ダイアログの表示は、視覚的なプロパティの問題です。
ダイアログの表示は、DOM内のdialog要素を取得してユーザーに見えるようにすることです。

dialog要素にtabindex属性を指定しない

dialog要素には、tabindex属性を指定してはなりません。

■関連項目

  • <details> …… 詳細情報を表す
  • <summary> …… 詳細情報の概要を表す
  • <dialog> …… ダイアログボックスを表す
  • <aside> …… メインコンテンツとは別のコンテンツであることを表す
  • <figure> …… キャプション情報を表す
  • <figcaption> …… figure要素のキャプションを表す
  • <small> …… 小さな活字にされる内容を表す
広告



山田 太郎
テック・リード
山田太郎は、ウェブ開発やグラフィックスプログラミングに10年以上の経験を持つテクノロジーの専門家です。特にHTML5 CanvasやJavaScript、インタラクティブメディアに精通しており、動的なユーザーインターフェースや最先端のウェブアプリケーションの開発に携わってきました。複雑な図形描画や画像操作、リアルタイムグラフィックスに関する知識が豊富で、ウェブ技術の限界を追求する開発者たちにとって頼りになる存在です。知識の共有に情熱を持ち、初心者からプロフェッショナルまで幅広く支援するため、技術フォーラムやブログにも積極的に貢献しています。

ギャンブルガイド もっと見る

カジノファインダー

どのカジノが自分に最適か分からないですか?

サインアップは必要なく、1 分以内に最適なブックメーカーを簡単に見つけることができます。
カジノを探す
Back
質問
Select one of the following options
{"is_any_tile":true}

どのカジノが自分に最適か分からないですか?

Back
Restart
やったー!
これはあなたの選択に基づいた最高のカジノです...
67 users signed up
もっと表示する