Гибкий:Вызов функции из включенного компонента

StackOverflow https://stackoverflow.com/questions/205359

  •  03-07-2019
  •  | 
  •  

Вопрос

Это похоже на мой предыдущий пост.Но на этот раз я хочу вызвать функцию, которая существует на главной странице mxml.

Это моя главная страница mxml:

main.mxml

<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" xmlns:ns1="*">
    <mx:Script>
        <![CDATA[   
        public function changeText(currentText:String):void{

            switch (currentText){
                case "changeText":
                    lblOne.text = "More Text";                  
            }
        }
            ]]>
    </mx:Script>

    <mx:HBox x="137.5" y="10" width="100%" height="100%">
        <ns1:menu id="buttons"> </ns1:menu>
    </mx:HBox>
    <mx:Canvas x="137" y="88" width="408.5" height="200">
        <mx:HBox x="0" y="10" width="388.5" height="190">
            <mx:Panel width="388" height="179" layout="absolute">
                <mx:Label x="10" y="10" text="Some Text" visible="{buttons.showLabel}" id="lblOne"/>
            </mx:Panel>
        </mx:HBox>
    </mx:Canvas>
</mx:Application> 

Вот моя включенная страница:

menu.mxml

<?xml version="1.0" encoding="utf-8"?>
<mx:Canvas xmlns:mx="http://www.adobe.com/2006/mxml" width="400" height="300">
    <mx:Script>
        <![CDATA[
            [Bindable] public var showLabel:Boolean = true;
        ]]>
    </mx:Script>
    <mx:MenuBar width="380" height="58"></mx:MenuBar>
    <mx:Button x="10" y="10" width="80" label="Show" id="btnOne" click="this.showLabel=true;" />
    <mx:Button x="94" y="10" width="80" label="Hide" id="btnTwo" click="this.showLabel=false;"/>
    <mx:Button x="181" y="10" width="80" label="Run Function" id="btnThree" click="{changeText('changeText')}"/>
</mx:Canvas>

Как мне вызвать функцию changeText с помощью кнопки в menu.mxml?

Это было полезно?

Решение

Добавьте это в меню:

  <mx:Metadata>
         [Event(name="buttonClicked", type="flash.events.Event")]
    </mx:Metadata>

 <mx:Button x="10" y="10" width="80" label="Show" id="btnOne" click="this.showLabel=true;dispatchEvent(new Event("buttonClicked"));"/>

Измените main на:

  <ns1:menu id="buttons" buttonClicked="changeText("Your Text");">

Я не мог сказать, откуда берется текущий текст, но если это из menu, возможно, вам придется создать свое собственное пользовательское событие flex или создать общую переменную для доступа к двум частям.Обычно предпочтительнее первое.

P.S.Использование метаданных события также может быть достигнуто путем добавления прослушивателя событий по завершении создания приложения.Вы бы добавили к основному:

buttons.addEventListener("buttonClicked",changeText("Your Text"));

Другие советы

есть более простой способ, просто используйте parentDocument .

Измени это:

<mx:Button x="181" y="10" width="80" label="Run Function" id="btnThree" click="{changeText('changeText')}"/>

Для:

<mx:Button x="181" y="10" width="80" label="Run Function" id="btnThree" click="{parentDocument*.changeText('changeText')}"/>**
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top