AsyncToken

包 mx.rpc
类 public dynamic class AsyncToken
继承 AsyncToken  EventDispatcher  Object

该类为异步 RPC 操作提供设置额外数据或标记级别数据的位置。它也允许为单独的调用附加 IResponder。可从 token 属性的 ResultEvent 和 FaultEvent 中引用 AsyncToken。

http://livedocs.adobe.com/flex/3_cn/langref/mx/rpc/AsyncToken.html

  在flex/AIR应用中使用多个外部调用,程序无法监听这些调用是否返回或何时返回结果(或者错误),也监听不到调用远程对象数据反回的顺序。你可能希望针对这些结果能有不同的处理。
  一种方式就是给每一个调用分配一个异步令牌(AsyncToken )来追踪这些调用。

  不要这样来进行远程调用:

Java 代码

   1. myRO.myRemoteMethod(); 

myRO.myRemoteMethod();


  你应该这样:

Java 代码

   1. var token:AsyncToken=myRO.myRemoteMethod();//确保导入了mx.rpc.AsyncToken 

var token:AsyncToken=myRO.myRemoteMethod();//确保导入了mx.rpc.AsyncToken



  现在就有了一个变量"token",代表这个单独的调用。你可以分配token自己的result和fault处理函数:

Java 代码

   1. token.addResponder(myResponderClass); 

token.addResponder(myResponderClass);


  这里myResponderClass类实现了IResponder.
  实现IResponder简单的意味着定义了如下两个方法签名:

引用
public function result(data:Object):void
  public function fault(info:Object):void

  因此你可以对程序的远程调用在调用时设置result和fault处理函数,而不用把硬编码放到你的远程对象,HTTPService或者 WebService标签里。这也恰好就是Cairngorm和其他微体系结构的运行方式。

  AsyncToken最后一点很酷的特性就是它是动态类。这意味着,当你进行远程调用时可以添加属性到token上,然后result/fault处理函数中读取这些属性。

   另外,在flex sdk3.4中有CallResponder,可以用CallResponder实例的token属性引用这个异步令牌。在flex sdk3.2中式没有这个类的,如果要用的话就只能自己写了,只要这个类继承自IResponder接口就可以了。

转载与http://jiale.iteye.com/blog/632961

你可能感兴趣的:(数据结构,webservice,Flex,Adobe,AIR)