У меня есть PopUpAnchor для отображения некоторого контента. Я добавил обработчик события mouseDownOutside
, поэтому, если пользователь щелкает за пределами всплывающего содержимого, всплывающее содержимое будет скрыто. Это прекрасно работает.PopUpAnchor - конфликт между обработчиками событий «click» и «mouseDownOutside»
Мне также понравится кнопка, которая управляет показом всплывающего окна для работы в качестве переключателя, так что, если всплывающее содержимое отображается и кнопка будет нажата, содержимое будет скрыто.
Что происходит в приведенном ниже коде, так это то, что при показе содержимого всплывающего окна, если кнопка нажата, вызывается обработчик события mouseDownOutside
, а затем обработчик click
, чтобы содержимое всплывающего окна было скрыто, а затем снова показано.
Есть ли способ разрешить это без сложности (например, добавление и удаление eventListeners на лету)?
<?xml version="1.0" encoding="utf-8"?>
<s:WindowedApplication xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
width="1024" height="768">
<fx:Script>
<![CDATA[
import mx.events.FlexEvent;
import mx.events.FlexMouseEvent;
protected function managePopup(event:MouseEvent):void
{
if (popupContent.isPopUp == false){
trace("managePopup -- opening");
popUp.displayPopUp = true;
} else {
trace("managePopup -- closing");
popUp.displayPopUp = false;
}
}
]]>
</fx:Script>
<s:Group x="10" y="10">
<!-- Button used to open PopUp -->
<s:Button id="openBtn" label="Open PopUp"
click="managePopup(event)"/>
<!-- PopUpAnchor component set to same size as openBtn to ensure that
popUp will be positioned relative to the button -->
<s:PopUpAnchor id="popUp"
popUpPosition="right"
width="92" height="21">
<!-- BorderContainer to hold popUp contents -->
<s:BorderContainer id="popupContent"
mouseDownOutside="managePopup(event)">
<s:layout>
<s:VerticalLayout paddingTop="5"
paddingLeft="5"
paddingBottom="5"
paddingRight="5"/>
</s:layout>
<s:Form>
<s:FormItem label="Name :">
<s:TextInput/>
</s:FormItem>
<s:FormItem label="E-Mail :">
<s:TextInput/>
</s:FormItem>
</s:Form>
<s:HGroup>
<!-- Button used to close popUp -->
<s:Button label="CLOSE" click="managePopup(event)"/>
</s:HGroup>
</s:BorderContainer>
</s:PopUpAnchor>
</s:Group>
</s:WindowedApplication>
Спасибо, что работает! Раньше не слышал об «MouseEvent.relatedObject». Также я склонен использовать 'id', а не' name', но я думаю, что 'id' является только функцией Flex, поскольку' event.relatedObject.id' выдает ошибку. –