Flex中的Array和ArrayCollection

当Array的数据发生变化的时候,用它作为数据源的控件不能感知这种变化。 
例如:myArray.push("new value"); 这时,如果一个List用它作为dataProvider,List的列表中不会增加新加入的这个值。 

而当ArrayCollection的数据发生变化的时候,能够通知控件发生变化。 
例如:myArrayCollection.addItem("new item"); 这时,如果一个控件List用它作为dataProvider,List列表中会增加一列内容 

另---------------------------------------------------------------------------------------
ArrayCollection实现接口ICollectionView,在Flex的类定义内属于[数据集],他提供更强大的检索、过滤、排 序、分类、更新监控等功能。FDK2提供的类似的类还有XMLListCollection 

这两者差别在于如果用array在作为data provider绑定于control之上,就无法获得控件的更新,除非控件被重新绘制或者data provider被重新指定,而Collection则是将array的副本存储于Collection类的某个对象之中,其特点是Collection 类本身就具备了确保数据同步的方法,例子:
复制代码
 1  <? xml version = " 1.0 "  encoding = " utf-8 " ?>
 2  < mx:Application xmlns:mx = " http://www.adobe.com/2006/mxml " >
 3         < mx:Script >
 4             <! [CDATA[
 5                 import  mx.collections.ArrayCollection;
 6                [Bindable]
 7                 public  var myArray:Array = [ " 北京 " , " 上海 " , " 深圳 " ];
 8                [Bindable]
 9                 public  var myCollection:ArrayCollection = new  ArrayCollection(myArray);
10                 public  function addCountryToArray(country:String): void {
11                    myArray.push(country);
12                }
13                 public  function addCountryToCollection(country:String): void {
14                    myCollection.addItem(country);
15                }
16            ]] >
17         </ mx:Script >
18         < mx:TextInput id = " countryTextInput "  text = " 广州 " />
19         < mx:Label text = " Bound to Array (Raw Object) " />
20         < mx:Button click = " addCountryToArray(countryTextInput.text) "  label = " Add Country to Array " />
21         < mx:List dataProvider = " {myArray} "  width = " 200 " />
22         < mx:Label text = " Bound to Collection " />
23         < mx:Button click = " addCountryToCollection(countryTextInput.text) "  label = " Add Country to Collection " />
24         < mx:List dataProvider = " {myCollection} "  width = " 200 " />
25  </ mx:Application >
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值