打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
【转】谈谈Flex中ArrayCollection的复制(克隆)
【转】谈谈Flex中ArrayCollection的复制(克隆)ofengofeng | 更新时间:2008-07-14 19:07:57 | 点击数:1029

在Flex的开发过程中,常常会遇到复制ArrayCollection的情况。以前只是从网上找个方法拿来就用,也没有具体的搞清楚所以然来。今天有时间,研究了一下,总结如下:

        Flex中的复制同java一样,也分为深复制和浅复制。

        下面总结一下ArrayCollection的浅复制,共有4种方法:

        1、var newArray:ListCollectionView=new ListCollectionView(ListCollectionView(oldArray).list);

        2、var newArray:ArrayCollection=new ArrayCollection(oldArray.source);

        3、var newArray:ArrayCollection=new ArrayCollection(oldArray.source.slice());

        4、var newArray:ArrayCollection=new ArrayCollection(oldArray.toArray());

        以上方法中,第一种方法由于不是创建的独立的ArrayCollection对象,所以不推荐使用。第二、三、四种方法相似,可以参考使用。

        有的时候,我们也会用到深复制,方法如下:

        var newArray:ArrayCollection=ArrayCollection(this.clone(oldArray));

        this.clone()方法定义如下:

         function clone(source:Object):*
         {
                var myBA:ByteArray = new ByteArray();
                myBA.writeObject(source);
                myBA.position = 0;
                return(myBA.readObject());
         }

下面是我测试以上程序的Flex程序代码,大家可以参考:

xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" creationComplete="initApp()" layout="absolute">
    
<mx:Script>
    

    
mx:Script>
    
<mx:Button label="第一种浅复制方法" click="test1()" x="61" y="36"/>
    
<mx:Button label="第二种浅复制方法" click="test2()" y="57" x="61" width="114"/>
    
<mx:Button label="第三种浅复制方法" click="test3()" y="78" x="61" width="114"/>
    
<mx:Button label="第四种浅复制方法" click="test4()" y="98" x="61" width="114"/>
    
    
<mx:Button label="深复制方法" click="test5()" y="147" x="61"/>
mx:Application>


本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
ArcGIS.Server.9.3和ArcGIS API for Flex在MapTips显示饼图数据统计(九)
Flex通用克隆(clone)方法
flex打印文档
Flex使用JSON格式与Java通信 - Flex - ITeye专栏频道
flex的array和arraycollection
JavaScript数组操作
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服