转载 Loader与URLLoader的区别

本文详细介绍了AS3中的Loader与URLLoader的区别与用法。Loader主要用于加载swf及图片文件,而URLLoader则适用于加载各类文本文件。文中通过实例展示了如何使用这两个类,并解释了Loader加载不同类型文件后的数据形式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

AS3已经中Loader与URLLoader是两个比较容易混淆的类,特此区分:
应用范围
Loader: swf,图片(jpg,png,gif)
URLLoader:文本文件(xml,php,jsp…)

使用方法
Loader:

loader.contentLoaderInfo.addEventListener(Event.COMPLETE, loadComplete); private function loadComplete(event:Event) { trace("done");addChild(loader);}


URLLoader:

xmlLoader.dataFormat=URLLoaderDataFormat.TEXT; xmlLoader.addEventListener(Event.COMPLETE,xmlLoaded); private function xmlLoaded(event:Event) { try {myXML = XML(event.target.data);area.text=myXML;} catch (e:TypeError) {area.text="Load faild:\n"+e.message;} }


Loader
在使用Loader来加载数据时,添加侦听事件时,注意一定要给Loader的 contentLoaderInfo属性增加事件,而不是给Loader对象增加事件。

var loader:Loader = new Loader();
loader.contentLoaderInfo.addEventListener(Event.COMPLETE, completeHandler);
loader.contentLoaderInfo.addEventListener(SecurityErrorEvent.SECURITY_ERROR, securityErrorHandler);
loader.contentLoaderInfo.addEventListener(IOErrorEvent.IO_ERROR, ioErrorHandler);

、Loader加载过来的数据类型
大家知道Loader是用来代替原来 MovieClip的loadMovie功能,用于加载外部的图片文件,SWF文件。
如果加载图片文件(jpg,gif,png等)时,Loader.content得到数据类型是Bitmap对象;
如果加载SWF文件(flash 9 版本)时,Loader.content得到数据类型是MovieClip对象;
如果加载SWF文件(flash 9 以前版本) 时, Loader.content得到数据类型是AVM1Movie对象;

具体见 http://livedocs.adobe.com/flex/3_cn/langref/flash/display/Loader.html#load ()


当加载操作已开始或套接字已接收到数据时,将调度 ProgressEvent 对象。这些事件通常在将 SWF 文件、图像或数据加载到应用程序中时生成。有两种类型的进程事件:ProgressEvent.PROGRESS 和 ProgressEvent.SOCKET_DATA。
ProgressEvent.PROGRESS 64K触发一次事件。

  1. actionscript中的 urlloader使用  
  2. 2009-03-15 / Read(2)  Comments(0)  Category: 其它技术  
  3. /*@post data to server*/  
  4. private function postData(src:String ,data:String ,callBack:Function):void  
  5. {  
  6.     var header1:URLRequestHeader  =  new  URLRequestHeader("Content-Type" ,"application/json; charset = utf -8");  
  7.     var header2:URLRequestHeader  =  new  URLRequestHeader("Accept" ,"application/json");  
  8.     var request:URLRequest  =  new  URLRequest(src);  
  9.     request.data  = data;  
  10.     request.method  =  URLRequestMethod .POST;  
  11.     request.requestHeaders  = [header1 ,header2];  
  12.       
  13.     var loader:urlloader  =  new  urlloader();  
  14.     loader.dataFormat  =  urlloaderDataFormat .TEXT;  
  15.     loader.addEventListener(Event.COMPLETE,  
  16.     function():void{  
  17.         callBack(loader.data);    
  18.     });  
  19.     loader.load(request);  
  20.       
  21. }  
  22. /*@get data from server*/  
  23. private function getData(src:String ,callBack:Function):void  
  24. {  
  25.     var header1:URLRequestHeader  =  new  URLRequestHeader("Content-Type" ,"application/json; charset = utf -8");  
  26.     var header2:URLRequestHeader  =  new  URLRequestHeader("Accept" ,"application/json");  
  27.     var request:URLRequest  =  new  URLRequest(src);  
  28.     request.method  =  URLRequestMethod .GET;  
  29.     request.requestHeaders  = [header1 ,header2];  
  30.       
  31.     var loader:urlloader  =  new  urlloader();  
  32.     loader.dataFormat  =  urlloaderDataFormat .TEXT;  
  33.     loader.addEventListener(Event.COMPLETE,  
  34.     function():void{  
  35.         callBack(loader.data);    
  36.     });  
  37.     loader.load(request);  
  38.       
  39. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值