1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
---
title: OpenClose
slug: Archive/Mozilla/XUL/PopupGuide/OpenClose
tags:
- XUL
- XUL Popup Guide
- 要更新
translation_of: Archive/Mozilla/XUL/PopupGuide/OpenClose
---
<div> <span id="Opening_and_Closing_Popups"></span></div>
<h3 id=".E3.83.9D.E3.83.83.E3.83.97.E3.82.A2.E3.83.83.E3.83.97.E3.81.AE.E9.96.8B.E9.96.89" name=".E3.83.9D.E3.83.83.E3.83.97.E3.82.A2.E3.83.83.E3.83.97.E3.81.AE.E9.96.8B.E9.96.89">ポップアップの開閉</h3>
<p>ポップアップとメニューはスクリプトによって開閉できます。</p>
<p><span id="Opening_Menus"></span></p>
<h4 id=".E3.83.A1.E3.83.8B.E3.83.A5.E3.83.BC.E3.82.92.E9.96.8B.E3.81.8F" name=".E3.83.A1.E3.83.8B.E3.83.A5.E3.83.BC.E3.82.92.E9.96.8B.E3.81.8F">メニューを開く</h4>
<p>メニューは特別な事をしなくても必要に応じて自動的に表示されます。たとえばメニューのポップアップはメニューのラベルがクリックされれば開きますし、サブメニューは親メニュー要素の上にマウスを乗せれば開きます。</p>
<p>しかし、手動でメニューを開きたい場合もあるでしょう。menu 要素には open プロパティがあり、true に設定するとメニューが開き、false に設定するとメニューが閉じます。 簡単な例を示します。</p>
<pre>somemenu.open = true;
</pre>
<p>この一行のコードによって変数 somemenu が参照するメニューが開きます。<code><span><a href="https://developer.mozilla.org/ja/docs/XUL/Property/open">open</a></span></code> プロパティを利用できるのは menu や button であり、menupopup ではないということに注意してください。メニューを開くためのボタンの完成例を示します。</p>
<pre><button label="Open Menu"
oncommand="document.getElementById('editMenu').open = true;"/>
<menu id="editMenu" label="Edit">
<menupopup>
<menuitem label="Cut"/>
<menuitem label="Copy"/>
<menuitem label="Paste"/>
</menupopup>
</menu>
</pre>
<p>この手法は <code>menu</code>、<code>button</code>、<code>toolbarbutton</code> のいずれのタグを使った menupopup に対しても用いることができます。<code id="a-popup"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/popup">popup</a></code> または <code id="a-context"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/context">context</a></code> 属性によって他の要素に取り付けられた menupopup については、下記の<a href="/ja/docs/XUL/PopupGuide/OpenClose#Opening_a_Popup">ポップアップを開く</a>を参照してください。</p>
<p>他の方法でメニューを開いた時と同様に、メニュー上に表示されるコマンドをカスタマイズできるように popupshowing イベントが発生します。</p>
<p>メニューを開くことができない状況がいくつかあります。</p>
<ul>
<li>メニューがすでに開いているか、開かれようとしている場合。当然ながら、すでに開いているメニューを開こうとしても何も効果はありません。</li>
<li>メニューが他のメニューの子であり、親メニューが開いていない場合。この場合、先に親メニューを開く必要があります。サブメニューを開くには、まず親メニューを開き、popupshown イベントリスナ内で子メニューを開きます。このやり方の例は <a href="/ja/docs/XUL/PopupGuide/PopupEvents#The_popupshown_Event">popupshown イベント</a> を参照してください。</li>
<li>Web ページなどの非特権コンテンツウィンドウのメニューは、ウィンドウにフォーカスがあり、現在アクティブなタブにある間にしかポップアップを開くことができません。つまり、バックグラウンドタブの中のドキュメントはメニューやポップアップを開くことはできません。</li>
</ul>
<p><span id="Closing_Menus"></span></p>
<h4 id=".E3.83.A1.E3.83.8B.E3.83.A5.E3.83.BC.E3.82.92.E9.96.89.E3.81.98.E3.82.8B" name=".E3.83.A1.E3.83.8B.E3.83.A5.E3.83.BC.E3.82.92.E9.96.89.E3.81.98.E3.82.8B">メニューを閉じる</h4>
<p>ユーザがメニューの中のどれかを選択すると、メニューは自動的に閉じます。メニューアイテムが選択されると、何らかの動作を実行するために command イベントが発生します。ユーザは Escape キーを押してコマンドの選択をキャンセルすることもできます。このときメニューは 1 つだけ閉じますが、そのメニューが親メニューを持つ場合、親メニューは開いたままです。また、メニューの外側をクリックしてメニューの選択をキャンセルすることもできます。この場合、そのメニューだけではなく、その全ての親メニューも閉じられます。</p>
<p>メニューをスクリプトから閉じるには、開くときとは逆に <code><span><a href="https://developer.mozilla.org/ja/docs/XUL/Property/open">open</a></span></code> プロパティを false に設定します。open プロパティを利用できるのは menu や button であり、menupopup ではありません。</p>
<pre>somemenu.open = false;
</pre>
<p>このコマンドは 1 つのレベルのメニューしか閉じないので、必要ならば同様のコマンドで親メニューを閉じなければなりません。しかし、この例の somemenu はすでに開いていないので、somemenu の子メニューはすべて閉じられます。たとえば、「ファイル」メニューに、最近使用したファイルの一覧を格納したサブメニューがあるとします。両方のメニューが開かれた状態でサブメニューの <code><span><a href="https://developer.mozilla.org/ja/docs/XUL/Property/open">open</a></span></code> プロパティを false に設定すると、サブメニューは閉じますが、親の「ファイル」メニューは開いたままです。反対に、「ファイル」メニューの open プロパティを false に設定すると、両方のメニューが閉じます。</p>
<p>この手法は <code>menu</code>、<code>button</code>、<code>toolbarbutton</code> のいずれのタグを使った menupopup に対しても用いることができます。<code id="a-popup"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/popup">popup</a></code> または <code id="a-context"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/context">context</a></code> 属性によって他の要素に取り付けられた menupopup については、下記の<a href="/ja/docs/XUL/PopupGuide/OpenClose#Closing_a_Popup_with_the_hidePopup_method">ポップアップを閉じる</a>を参照してください。</p>
<p>メニューが閉じると、menupopup で popuphiding イベントが発生します。popuphiding イベントをリスンするイベントリスナを取り付けることで、popupshowing イベント中に追加したコマンドを削除するといったことが可能になります。</p>
<p>メニューやポップアップは、それを含むドキュメントやウィンドウが閉じられたときや、menupopup 要素がドキュメントから削除されたときにも閉じられます。こういった場合には、イベントの発生元となる要素が存在しないので、popuphiding や popuphidden イベントは発生しません。これらのイベントで行われるような<span style="border-bottom: 1px dashed green;" title="uninitialization">終了処理</span>を実行したければ、unload イベント中に行うのがいいでしょう。</p>
<p><span id="Testing_Menu_Open_State"></span></p>
<h4 id=".E3.83.A1.E3.83.8B.E3.83.A5.E3.83.BC.E3.81.8C.E9.96.8B.E3.81.84.E3.81.A6.E3.81.84.E3.82.8B.E3.81.8B.E8.AA.BF.E3.81.B9.E3.82.8B" name=".E3.83.A1.E3.83.8B.E3.83.A5.E3.83.BC.E3.81.8C.E9.96.8B.E3.81.84.E3.81.A6.E3.81.84.E3.82.8B.E3.81.8B.E8.AA.BF.E3.81.B9.E3.82.8B">メニューが開いているか調べる</h4>
<p>メニューが開いているかどうかを調べるには、そのメニューの <code><span><a href="https://developer.mozilla.org/ja/docs/XUL/Property/open">open</a></span></code> プロパティを調べます。open プロパティが true に設定されていればそのメニューは開いており、そうでなければ閉じられています。</p>
<pre>var open = somemenu.open;
</pre>
<p><span id="Opening_a_Popup"></span></p>
<h4 id=".E3.83.9D.E3.83.83.E3.83.97.E3.82.A2.E3.83.83.E3.83.97.E3.82.92.E9.96.8B.E3.81.8F" name=".E3.83.9D.E3.83.83.E3.83.97.E3.82.A2.E3.83.83.E3.83.97.E3.82.92.E9.96.8B.E3.81.8F">ポップアップを開く</h4>
<p><code>menu</code> タグ、<code>button</code> タグ、<code>toolbarbutton</code> タグを使った menupopup を開くには、上記の<a href="/ja/docs/XUL/PopupGuide/OpenClose#Opening_Menus">メニューを開く</a>を参照してください。</p>
<p><code id="a-popup"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/popup">popup</a></code> attribute によって取り付けられたポップアップは、ユーザが左マウスボタンをクリックすると開きます。キーボードによってこの動作を再現することはできないので、必ずそのメニューの機能にアクセスする別の方法を用意するようにしてください。これはユーザインタフェースのほかの場所に代わりになるコマンドを設置するか、メニューを開くショートカットを用意することで可能になります。メニューが開かれれば、通常どおりキーボードによってアイテム間を移動して選択することができます。</p>
<p><code id="a-context"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/context">context</a></code> 属性によって取り付けられたポップアップは、ユーザがコンテキストメニューを開こうとする動作を行ったときに開きます。この動作はプラットフォームごとに異なりますが、一般的には要素を右マウスボタンでクリックする必要があります。マウスボタンが 1 つしかない Macintosh システムでは、マウスボタンを押し続けるか、Control キーを押しながらマウスボタンをクリックするとコンテキストメニューが開かれます。Windows では、キーボードのメニューキー (多くのキーボードで Control キーの隣にある、メニューの絵が描かれたキー) を押すか、Shift + F10 キーを押してコンテキストメニューを開く事も出来ます。したがって、ユーザがコンテキストメニューを開くのにマウスを使うものだと決めてかかってはいけません。</p>
<p><span id="The_openPopup_method"></span></p>
<h5 id="openPopup_.E3.83.A1.E3.82.BD.E3.83.83.E3.83.89" name="openPopup_.E3.83.A1.E3.82.BD.E3.83.83.E3.83.89">openPopup メソッド</h5>
<p>ポップアップの <span id="m-openPopup"><code><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Method/openPopup">openPopup</a></code></span> メソッドを使うと、ポップアップの種類に関係なくプログラムからポップアップを開くことができます。このメソッドは menupopup、panel、tooltip のどの種類のポップアップでも使用でき、また <code id="a-context"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/context">context</a></code> 属性によって取り付けられたポップアップなど他の方法で開かれるポップアップでも使用できます。</p>
<p><span id="m-openPopup"><code><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Method/openPopup">openPopup</a></code></span> メソッドは、ポップアップをどこにどのように配置するかを指定する 6 つの引数を取ります。これらの引数について以下で説明します。<code>openPopup</code> メソッドは次のように定義されています。</p>
<pre>void openPopup(in DOMElement anchorElement,
in String position,
in long x,
in long y,
in boolean isContextMenu,
in boolean attributesOverride);
</pre>
<p>まず例を示します。</p>
<pre>somepopup.openPopup(anchor, "after_start", 0, 0, false, false);
</pre>
<p>この例は anchor で参照されるほかの要素のすぐ下にポップアップを開きます。これは anchor が <code><a href="/ja/docs/Mozilla/Tech/XUL/menu" title="menu">menu</a></code> 要素であった場合の動作を模倣しています。メニューに対して <code>openPopup</code> メソッドを使うこともできますが、そのメニューの <code id="a-open"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/open">open</a></code> 属性を true に設定した方が、menupopup の位置を代わりに処理してくれるのでより簡単です。open 属性は親のメニューや親のボタンで利用できるのに対して、<code>openPopup</code> メソッドは menupopup 要素で利用できるということに注意してください。</p>
<p>ポップアップのアンカーとは、それに隣接してポップアップが表示される要素ノードのことです。たとえば、あるボタンの隣にポップアップを表示させたければ、そのボタンへの参照を第一引数として <code>openPopup</code> メソッドに渡します。次の例では、ポップアップが文書要素からの相対的な位置に開かれます。</p>
<pre>somepopup.openPopup(document.documentElement, "end_before", 0, 0, false, false);
</pre>
<p>openPopup の第二引数はアンカーの <code>position</code> で、これはアンカーのどの辺に対してポップアップを配置するかを指定します。たとえば上の例で使用されている end_before という値を指定すると、ポップアップの左辺がアンカー要素の右辺に接し、双方の上端が揃うように配置されます。この引数はわかりにくいので、<a href="/ja/docs/XUL/PopupGuide/Positioning">ポップアップの位置決め</a>で詳しい利用方法と取り得る値、またそれぞれの値でポップアップがどのように位置合わせされるかを示す画像を参照してください。</p>
<p>openPopup の第三引数と第四引数は、オフセット値 <code>x</code> と <code>y</code> です。これらのオフセット値にゼロ以外の値を指定すると、ポップアップが位置決めされてからさらにポップアップの位置を指定することができます。これにより、ポップアップを特定の要素の位置に固定させつつ、その位置を細かく調整することが可能になります。正の値を指定するとポップアップの位置が右か下に調整され、負の値を指定すると左か上に調整されます。</p>
<p>次の例ではポップアップが要素の下に表示されますが、右に 10 pixel、上に 2 pixel オフセットされます。</p>
<pre>somepopup.openPopup(anchor, "after_start", 10, -2, false, false);
</pre>
<p>アンカーと位置決めは、ポップアップが開かれるときの位置のみを指定するということに注意してください。ポップアップが開いている間にアンカーが移動または削除されても、ポップアップはそれに従いません。しかし、ポップアップが開かれている間にポップアップを動かすことは可能です。<a href="/ja/docs/XUL/PopupGuide/MoveResize">ポップアップの移動とリサイズ</a>を参照してください。</p>
<p>openPopup の第五引数 <code>isContextMenu</code> は、ポップアップをコンテキストメニューとして開くかどうかを指定するフラグです。コンテキストメニューとして開きたければ true を、そうでなければ false を渡します。この引数に何を設定するかはあなたがどんな方法で openPopup を呼び出すかによって明らかでしょう。同じメニューをどちらの方法で開くこともできるので、このフラグはポップアップがどのように表示されるかには影響しないということに注意してください。これが影響するのは、メニューのフォーカスやハイライトが処理される方法です。状況に応じて適切な値を渡している限りは、双方の細かい違いを知る必要はありません。</p>
<p>しかしながら、Firefox のブックマークを使ってこのフラグの効果を確かめることができます。ブックマークのサブメニュー (ブックマークフォルダ) を開いてみてください。マウスが他のメニューの上に移動するとともにハイライトが変更され、マウスが離れるとサブメニューが閉じることがわかります。今度は同じブックマーク上でコンテキストメニューを開いてみてください。マウスを移動しても他のメニューには影響が無いのがわかります。この違いは isContextMenu フラグの使用によって処理されたものです。</p>
<p><code>openPopup</code> メソッドの最後の引数 <code>attributesOverride</code> は、ポップアップの要素自体に設置された属性が、与えられた引数を上書きするかどうかを指定します。これによりポップアップは <code id="a-position"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/position">position</a></code>、<code id="a-left"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/left">left</a></code>、<code id="a-top"><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Attribute/top">top</a></code> 属性で指定された位置決めの動作を使用することができます。これらの属性の詳細は<a href="/ja/docs/XUL/PopupGuide/Positioning">ポップアップの位置決め</a>にあります。</p>
<p><span id="Unanchored_Popups_with_openPopup"></span></p>
<h5 id="openPopup_.E3.81.AB.E3.82.88.E3.82.8B.E3.82.A2.E3.83.B3.E3.82.AB.E3.83.BC.E3.81.95.E3.82.8C.E3.81.AA.E3.81.84.E3.83.9D.E3.83.83.E3.83.97.E3.82.A2.E3.83.83.E3.83.97" name="openPopup_.E3.81.AB.E3.82.88.E3.82.8B.E3.82.A2.E3.83.B3.E3.82.AB.E3.83.BC.E3.81.95.E3.82.8C.E3.81.AA.E3.81.84.E3.83.9D.E3.83.83.E3.83.97.E3.82.A2.E3.83.83.E3.83.97">openPopup によるアンカーされないポップアップ</h5>
<p><span id="m-openPopup"><code><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Method/openPopup">openPopup</a></code></span> メソッドの第一引数が null だと、アンカーされないポップアップが作成されます。この場合、第二引数 position は使用されないため、空文字列を渡してもかまいません。例を示します。</p>
<pre>somepopup.openPopup(null, "", 60, 50, false, false);
</pre>
<p>アンカーされないポップアップはオフセット値 x と y 、この場合は 60 と 50 を、ウィンドウまたはフレームの端からのオフセットとして使用します。この方法では、ポップアップは特定のノードではなく、ウィンドウからの相対的な位置に配置されます。たとえば、マウスをクリックした時に、現在マウスポインタがある位置にポップアップを表示させたいことがあるでしょう。click イベントリスナの例を示します。</p>
<pre>function mouseClicked(event)
{
var panel = document.getElementById("some-panel");
panel.openPopup(null, "", event.clientX, event.clientY, false, false);
}
</pre>
<p><span id="The_openPopupAtScreen_method"></span></p>
<h5 id="openPopupAtScreen_.E3.83.A1.E3.82.BD.E3.83.83.E3.83.89" name="openPopupAtScreen_.E3.83.A1.E3.82.BD.E3.83.83.E3.83.89">openPopupAtScreen メソッド</h5>
<p>2 つめのメソッド <span id="m-openPopupAtScreen"><code><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Method/openPopupAtScreen">openPopupAtScreen</a></code></span> は、ポップアップを画面上の特定の座標に配置するのに利用できます。このメソッドではポップアップは要素にアンカーされず、引数 <code>x</code> と <code>y</code> で指定された特定の位置に表示されます。</p>
<pre>void openPopupAtScreen(in long x, in long y, in boolean isContextMenu);
</pre>
<p>引数 <code>isContextMenu</code> は、コンテキストメニューを開くように指示します。これは <code>openPopup</code> メソッドのものと同じ機能を持っています。次の例では、水平位置 100、垂直位置 200 にポップアップが開かれます。</p>
<pre>popup.openPopupAtScreen(100, 200, false);
</pre>
<p>ポップアップが部分的もしくは全体的にスクリーンから出るような位置に座標が指定されると、ポップアップは全体が見えるように移動され、必要に応じてリサイズされる事に注意してください。</p>
<p><span id="Closing_a_Popup_with_the_hidePopup_method"></span></p>
<h4 id="hidePopup_.E3.83.A1.E3.82.BD.E3.83.83.E3.83.89.E3.81.A7.E3.83.9D.E3.83.83.E3.83.97.E3.82.A2.E3.83.83.E3.83.97.E3.82.92.E9.96.89.E3.81.98.E3.82.8B" name="hidePopup_.E3.83.A1.E3.82.BD.E3.83.83.E3.83.89.E3.81.A7.E3.83.9D.E3.83.83.E3.83.97.E3.82.A2.E3.83.83.E3.83.97.E3.82.92.E9.96.89.E3.81.98.E3.82.8B">hidePopup メソッドでポップアップを閉じる</h4>
<p>ユーザが Escape キーを押すかポップアップの外側のどこかをクリックすると、ポップアップメニューは閉じます。</p>
<p><code>menu</code>、<code>button</code>、<code>toolbarbutton</code> タグを使った menupopup を閉じる方法は、上記の<a href="/ja/docs/XUL/PopupGuide/OpenClose#Closing_Menus">メニューを閉じる</a>を参照して下さい。</p>
<p>スクリプトによってポップアップを閉じるには、ポップアップの <span id="m-hidePopup"><code><a href="https://developer.mozilla.org/ja/docs/Mozilla/Tech/XUL/Method/hidePopup">hidePopup</a></code></span> メソッドを使います。このメソッドは引数を取りません。</p>
<pre>popup.hidePopup();
</pre>
<p><span id="Determining_if_a_Popup_is_Open"></span></p>
<h4 id=".E3.83.9D.E3.83.83.E3.83.97.E3.82.A2.E3.83.83.E3.83.97.E3.81.8C.E9.96.8B.E3.81.84.E3.81.A6.E3.81.84.E3.82.8B.E3.81.8B.E3.81.A9.E3.81.86.E3.81.8B.E5.88.A4.E5.88.A5.E3.81.99.E3.82.8B" name=".E3.83.9D.E3.83.83.E3.83.97.E3.82.A2.E3.83.83.E3.83.97.E3.81.8C.E9.96.8B.E3.81.84.E3.81.A6.E3.81.84.E3.82.8B.E3.81.8B.E3.81.A9.E3.81.86.E3.81.8B.E5.88.A4.E5.88.A5.E3.81.99.E3.82.8B">ポップアップが開いているかどうか判別する</h4>
<p>メニューに関しては、menu、button もしくは toolbarbutton の <code><span><a href="https://developer.mozilla.org/ja/docs/XUL/Property/open">open</a></span></code> プロパティを調べれば判別できます。true ならメニューは開いています。</p>
<p>他の種類のポップアップでは、<code><span><a href="https://developer.mozilla.org/ja/docs/XUL/Property/state">state</a></span></code> プロパティを調べればポップアップが開いているかどうかを判別できます。このプロパティはメニュー、パネル、ツールチップを含む全ての種類のポップアップで利用できます。表示されているポップアップの <code>state</code> プロパティは <code>open</code> という値を持ち、ポップアップが閉じると <code>state</code> プロパティの値は <code>closed</code> になります。このプロパティは読み込み専用で、<code><a href="/ja/docs/Mozilla/Tech/XUL/menupopup" title="menupopup">menupopup</a></code>、<code><a href="/ja/docs/Mozilla/Tech/XUL/panel" title="panel">panel</a></code> または<code><a href="/ja/docs/Mozilla/Tech/XUL/tooltip" title="tooltip">tooltip</a></code> 要素で利用できます。</p>
<p><code>state</code> プロパティは他にもう 2 つの値を持つことがあります。これらの値は、ポップアップが開いている状態から閉じている状態へ、またはその逆へと移行する間に使用されます。ポップアップが表示されようとしている時には <code>state</code> プロパティは <code>showing</code> という値を持ち、ポップアップが消されようとしている時には <code>hiding</code> という値を持ちます。前者は <a href="/ja/docs/XUL/PopupGuide/PopupEvents#The_popupshowing_event">popupshowing</a> イベント中に起こり、後者は <a href="/ja/docs/XUL/PopupGuide/PopupEvents#The_popuphiding_event">popuphiding</a> イベント中に起こります。</p>
<p>たとえば、<code>state</code> プロパティは <code>panel</code> がすでに開かれているかどうかを判別するのに使用できます。パネルが開かれている場合、ユーザはメインウィンドウ内のユーザインタフェースを直接操作していないので、操作を無効にするといったことも可能になります。</p>
|