flex学习记录——控制函数的执行顺序

 

      在调用函数的时候,有时我们希望先执行完一个函数,然后再执行另一个一个函数;或者需要先执行一个函数,并得到这个函数的执行结果,根据这个结果去执行另一个函数。一般地,我们习惯只是排放函数的位置先后关系,以为这样函数就能按照我们的意愿去执行,然后结果总让人失望。暂未清楚其具体原因,只知其不可行,下面是一种解决方法:通过监听实现。

<?xml version="1.0" encoding="utf-8"?>
<mx:Application  xmlns:mx="http://www.adobe.com/2006/mxml"    width="100%" height="100%"    pageTitle="函数执行顺序" 
creationComplete="initApp();"> <mx:Script> <![CDATA[ import mx.rpc.events.FaultEvent; import mx.rpc.events.ResultEvent; import mx.controls.Alert; import mx.containers.VBox; private var countdf:int = 0; private function initApp():void{ menuService2.addEventListener(ResultEvent.RESULT,sfshow); //监听函数 menuService2.getCountByUserId(userid); } private function sfshow(event:ResultEvent):void{ countdf = event.result as int; if(countdf>0){ Alert.show("countdf"+countdf); } } ]]> </mx:Script> <mx:RemoteObject id="menuService2" destination="menuService"/> <mx:VBox width="100%" height="100%" paddingBottom="0" paddingLeft="0" paddingRight="0" paddingTop="0"> </mx:VBox> </mx:Application >

 

另一种实现方式:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application  xmlns:mx="http://www.adobe.com/2006/mxml"    width="100%" height="100%"    pageTitle="函数执行顺序" 
    creationComplete="initApp();">
    <mx:Script>
        <![CDATA[
            import mx.rpc.events.FaultEvent;
            import mx.rpc.events.ResultEvent;
            import mx.controls.Alert;
            import mx.containers.VBox;


            private var countdf:int = 0;
           
        
        private function initApp():void{
         menuService2.getCountByUserId(userid);
        }
        private function sfshow(event:ResultEvent):void{
            
            countdf = event.result as int;
            
            if(countdf>0){
                
                Alert.show("countdf"+countdf);
            }
        }
        ]]>
    </mx:Script>
    <mx:RemoteObject id="menuService2" destination="menuService">
<mx:method name="getCountByUserId" result="sfshow(event)"/>
    <mx:VBox width="100%" height="100%" paddingBottom="0" paddingLeft="0" paddingRight="0" paddingTop="0">

    </mx:VBox>
    
</mx:Application >

 

转载于:https://www.cnblogs.com/zhangchunxi/archive/2012/11/15/2771054.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值