Flex上传文件功能

From: http://www.cnblogs.com/midea0978/archive/2008/08/06/1262260.html


写过很多文件上传的功能,包括AJAX实现动态监控上传进度的,现在看到了FLEX实现文件上传功能,还真是很方便,没什么好说的,上代码:

upload.mxml

复制代码
<? xml version="1.0" encoding="utf-8" ?>
< mx:Application  xmlns:mx ="http://www.adobe.com/2006/mxml"  creationComplete ="init()"  layout ="absolute"  width ="497"  height ="136"  backgroundGradientAlphas ="[1.0, 1.0]"  backgroundGradientColors ="[#F2F8F8, #45E7E5]" >
    
< mx:Script  source ="upload.as" ></ mx:Script >
    
< mx:Style >
        .myfont{font-size:13pt}
    
</ mx:Style >
    
< mx:Button  x ="10"  y ="95"  label ="上传文件"  click ="pickfile()"  styleName ="myfont" />
    
< mx:Label  x ="10"  y ="10"  text ="文件上传"  styleName ="myfont" />
    
< mx:ProgressBar  x ="10"  y ="40"  width ="457"  themeColor ="#F20D7A"  minimum ="0"  mode ="manual"  maximum ="100"  id ="progress1"  label ="当前进度: 0%"  styleName ="myfont"  fontWeight ="normal" />
    
< mx:Label  x ="146"  y ="98"  width ="321"  id ="lbProgress"  styleName ="myfont"  textAlign ="right" />
</ mx:Application >
复制代码

upload.as

 

复制代码
 1  //  ActionScript file
 2  import  flash.events.Event;
 3  import  flash.net.FileFilter;
 4  import  flash.net.FileReference;
 5  private  var fileRef:FileReference  =   new  FileReference();
 6  private  function init(): void {
 7      
 8  }
 9 
10  private  function pickfile(): void {
11      var imageTypes:FileFilter  =   new  FileFilter( " 图片 (*.jpg, *.jpeg, *.gif,*.png) " " *.jpg; *.jpeg; *.gif; *.png " );
12      var textTypes:FileFilter  =   new  FileFilter( " 文本文件(*.txt " , " *.txt; " );
13      var officeType:FileFilter  =   new  FileFilter( " Office文件(*.doc, *.xls " , " *.doc; *.xls " );
14      var anyType:FileFilter  =   new  FileFilter( " 所有文件(*.*) " , " *.* " );
15      var allTypes:Array  =   new  Array(imageTypes, textTypes,officeType,anyType);
16      fileRef.addEventListener(Event.SELECT, selectHandler);
17      fileRef.addEventListener(Event.COMPLETE, completeHandler);
18      fileRef.addEventListener(ProgressEvent.PROGRESS, progressHandler);
19      fileRef.addEventListener( " ioError " , ioerrorHandler);
20       try {
21          var success:Boolean  =  fileRef.browse(allTypes);
22      } catch  (error:Error){
23          trace( " Unable to browse for files. " + error.toString());
24      }
25  }
26  private  function ioerrorHandler(event:Event): void {
27      trace( " Unable to upload file. " + event.toString());
28  }
29  private  function progressHandler(event:ProgressEvent): void {
30      lbProgress.text  =   "  已上传  "   +  (event.bytesLoaded / 1024 ).toFixed( 2 ) +   "  K,共  "   +  (event.bytesTotal / 1024 ).toFixed( 2 +   "  K " ;
31      var proc: uint  =  event.bytesLoaded  /  event.bytesTotal  *   100 ;
32      progress1.setProgress(proc,  100 );
33      progress1.label =   " 当前进度:  "   +   "   "   +  proc  +   " % " ;
34 
35  }
36  private     function selectHandler(event:Event): void {
37      var request:URLRequest  =   new  URLRequest( " http://localhost:9080/upload/upload.jsp " )
38       try
39      {
40          fileRef.upload(request);
41      }
42       catch  (error:Error)
43      {
44          trace( " Unable to upload file. " + error.toString());
45      }
46  }
47  private  function completeHandler(event:Event): void {
48      trace( " uploaded " );
49  }
50 
51 
复制代码

效果图:

 


你可能感兴趣的:(Flex上传文件功能)