モーダルウィンドウ

出典: フリー百科事典『ウィキペディア(Wikipedia)』
ナビゲーションに移動 検索に移動

モーダルウィンドウ: modal window)は、コンピュータアプリケーションソフトウェアユーザインタフェース設計において、何らかのウィンドウの子ウィンドウとして生成されるサブ要素のうち、ユーザーがそれに対して適切に応答しない限り、制御を親ウィンドウに戻さないもの。モーダルウィンドウはGUIシステムで、ユーザーに注意を促したり、選択肢を提示したり、緊急の状態を知らせたりする目的でよく使われる。モーダルダイアログポップアップと呼ばれることもある[1][2]

"modal"とは「モードを持つ」という意味であり、モーダルウィンドウが表示されている間はアプリケーションの状態が「ユーザーの応答待ちモード」になっている。対義語は"modeless"(モードレス)である。

ユースケース[編集]

モーダルウィンドウは以下のような状況でよく使われる。

  • 特に重要な情報への注意を喚起する。この用法は効果的ではないという批判もある[3] [4] [5]
  • 必要な入力がなされるまで、アプリケーションの実行をブロックする。
  • アプリケーションの設定オプションを1つのダイアログに集約する。
  • これから実行しようとしている操作は取り消すことができないことを警告する。ファイルの書き込みや削除でよく見られるが、その意図する効果(間違った操作を防ぐ)は疑問視する向きもあり、代替策もある[6]

類似要素[編集]

Microsoft Windows では、Mac OSX Window System ベースのUNIX系システムよりもモーダルウィンドウがよく使われる[要出典]。Windows でモーダルウィンドウが使われるような状況で、それ以外の環境ではトランジェントウィンドウ (transient window) が使われる。トランジェントウィンドウはモーダルウィンドウと似たような振る舞いをし、常に親ウィンドウの前面に表示され、ウィンドウリストには出現しないが、同じアプリケーションの他のウィンドウの使用を妨げない。

利点と問題点[編集]

モーダルウィンドウは、クローズされるまでそのプログラムの他のワークフロー全体をブロックする。ユーザーはモーダルウィンドウが注意を喚起していることに気づかない場合もあり、主ウィンドウが反応しなくなったことで困惑したり、入力すべきデータが判らなくなったりするといった問題も発生する。モードの明確化という点に関しては、ダイアログ表示中に背景となる主ウィンドウの明るさを下げてコントラストをつけることで配慮している例もある(WindowsランタイムWindows.UI.Popups.MessageDialogや、Androidandroid.app.AlertDialogなど)。

モーダルウィンドウに対する意見は、初期のマンマシンインタフェースにおける基本原則を想起させる。例えば、マイクロソフトWindows 95ウィザードを多用した[7]

[いつ?]もモーダルウィンドウは多くのGUIツールキットの主要部品の1つであり、よく使われる。多数のモードのないダイアログが表示されるとユーザーが混乱すると考えられているためであり、モーダルウィンドウを擁護する立場からは、ある時間内にユーザーが入力しなければならない情報の量を制限することができるという意見もある。また、モーダルウィンドウとの対話中はユーザーによって親ウィンドウを操作されることがないため、ワークフローの管理や画面遷移の実装の容易さの観点からも有用である。

一方で、ユーザインタフェースの専門家は、そのような意見に対して、ユーザーにフラストレーションを与えてまで制限を加えるのは誤りだと指摘している[8]。ユーザーは1度に1つの入力しかできず、モーダルだろうとなかろうとユーザーは常に注意していなければならない。たとえ複雑な情報であっても、それがうまく構造化された論理的設計で表現されていれば、ユーザーはそれを処理できる[要説明]

脚注[編集]

  1. ^ モーダルダイアログとは|モーダルウィンドウ|modal dialog : 意味/定義 - IT用語辞典
  2. ^ ポップアップとは|pop-up : 意味/定義 - IT用語辞典
  3. ^ Joel Spolsky, User Interface Design for Programmers: Designing for People Who Have Better Things To Do With Their Lives
  4. ^ Raymond Chen, The Old New Thing: The default answer to every dialog box is "Cancel"
  5. ^ Jeff Atwood, Coding Horror: Teaching Users to Read
  6. ^ Aza Raskin, A List Apart: Never Use a Warning When you Mean Undo
  7. ^ David A. Karp, HELP WITH WINDOWS 98
  8. ^ Cooper, Alan (2003年3月17日). About Face 2.0: The Essentials of Interaction Design. Wiley. ISBN 0764526413. 

[編集]

  • ThickBox - jQuery 上に構築された JavaScript のモーダルウィンドウ
  • TinyBox - Prototype 上に構築された JavaScript のモーダルウィンドウ
  • subModal - DHTMLのモーダルダイアログ
  • Control.Modal by Live Pipe
  • MOOdalBox - mootools 上のモーダルボックス
  • Lightbox JS by Lokesh Dhakar
  • GreyBox by Amir Salihefendic

関連項目[編集]