Flex 4:状态变化事件

时间:2010-10-20 23:53:29

标签: actionscript-3 flex flex4

我可以使用Flex 4中的任何事件来检测状态变化吗?

3 个答案:

答案 0 :(得分:16)

我知道这个问题已经过时了,但是通过谷歌搜索状态变化事件,我仍然会在这里找到想要了解的人:

组件调度了一个StateChangeEvent.CURRENT_STATE_CHANGE事件,因此您的应用程序也可以监听它。

在您的侦听器功能中,您可以访问StateChangeEvent.oldStateStateChangeEvent.newState属性。

答案 1 :(得分:9)

如果你正在讨论视图状态,答案是肯定的,你可以像这样监听enterState事件(对于示例的简单性而言,这是我正在进行的项目的一部分,我删除了任何相关部分代码):

<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
           xmlns:s="library://ns.adobe.com/flex/spark" 
           xmlns:mx="library://ns.adobe.com/flex/mx"
           minWidth="800" minHeight="600"
           currentState="loading">

<fx:Script>
    <![CDATA[
        import mx.controls.Alert;

        private function onEnterLoadingState():void{
            Alert.show("Enter the loading state.", "Application");
        }

        private function onEnterLoginState():void{
            Alert.show("Enter the login state.", "Application");
        }

        private function onEnterAddState():void{
            Alert.show("Enter the addUser state.", "Application");
        }

        private function changeState(state:String):void{
            currentState = state;
        }
    ]]>
</fx:Script>

<s:states>
    <s:State name="loading" enterState="onEnterLoadingState()"/>
    <s:State name="login" enterState="onEnterLoginState()"/>
    <s:State name="addUser" enterState="onEnterAddState()"/>
</s:states>

<s:Panel id="loadView" includeIn="loading" title="Loading">
    <s:Button label="Go to login" click="changeState('login')"/>
</s:Panel>
<s:Panel id="loginView" includeIn="login" title="Login">
    <s:Button label="Go to addUser" click="changeState('addUser')"/>
</s:Panel>
<s:Panel id="addView" includeIn="addUser" title="AddUser">
    <s:Button label="Return to loading" click="changeState('loading')"/>
</s:Panel>
</s:Application>

如果需要,还有一个exitState事件。我希望这会对你有所帮助。

答案 2 :(得分:0)

您可以在任何UIComponent类上侦听多个状态事件:

  • FlexEvent.STATE_CHANGE_COMPLETE
  • FlexEvent.STATE_CHANGE_INTERRUPTED
  • StateChangeEvent.CURRENT_STATE_CHANGING
  • StateChangeEvent.CURRENT_STATE_CHANGE
  • FlexEvent.ENTER_STATE
  • FlexEvent.EXIT_STATE

MXML:

<?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"

                       enterState="windowedapplication1_enterStateHandler(event)"
                       exitState="windowedapplication1_exitStateHandler(event)"
                       currentStateChange="windowedapplication1_currentStateChangeHandler(event)"
                       currentStateChanging="windowedapplication1_currentStateChangingHandler(event)"
                       stateChangeInterrupted="windowedapplication1_stateChangeInterruptedHandler(event)"
                       stateChangeComplete="windowedapplication1_stateChangeCompleteHandler(event)">

    <fx:Script>
        <![CDATA[
            import mx.events.FlexEvent;


            protected function windowedapplication1_stateChangeCompleteHandler(event:FlexEvent):void
            {

            }

            protected function windowedapplication1_stateChangeInterruptedHandler(event:FlexEvent):void
            {

            }

            protected function windowedapplication1_currentStateChangeHandler(event:StateChangeEvent):void
            {
                var oldState:String = event.oldState;
                var newState:String = event.newState;
            }

            protected function windowedapplication1_currentStateChangingHandler(event:StateChangeEvent):void
            {
                var oldState:String = event.oldState;
                var newState:String = event.newState;
            }

            protected function windowedapplication1_enterStateHandler(event:FlexEvent):void
            {

            }

            protected function windowedapplication1_exitStateHandler(event:FlexEvent):void
            {

            }
        ]]>
    </fx:Script>
</s:WindowedApplication>