首页 > 网站 > WEB开发 > 正文

5.3.为List的内容变更添加特效

2024-04-27 13:51:56
字体:
来源:转载
供稿:网友
5.3.1 问题
当list 的数据被改变的时候为list 添加显示效果
5.3.2 解决方法
创建一个效果序列并将它们传递给List 组件的itemsChangeEffect 属性
5.3.3 讨论
数据改变时效果是flex 3 新增的很强大的效果,对于之前的版本,你可以写数据改变时效果并分发和注册事件和事件侦听,但是伴随着flex 3 新增itemsChangeEffect 属性,List 组件和任何继承ListBase 的类都可以在它的dataProvider 改变时分发事件,然后该事件触发所有传递给List 中新的itemsChangeEffect 属性的效果或效果序列.

由于dataChange 事件是由List 的dataProvider 触发的,设置一个类似List 组件的dataProvider 的数组意味着该数组被改变时itemsChangeEffect 事件不会被分发。记住,事件被改变时不分发事件,对于ArrayCollection 类,当事件被改变时仍然会分发事件,类似继承自EventDispatcher 并设置成分发事件一样,当一个设置方法被调用来改变潜在的数组对象的值简单地将itemsChangeEffect 设置为一个2 秒淡出的DefaultListEffect 的实例,下面这个例子是当List 被改变时应用一个mx.effects.Glow 实例的效果:
 
+展开
-XML
<mx:VBox xmlns:mx="http://www.adobe.com/2006/mxmlwidth="400height="900top="20left="20">
<mx:Script>
<![CDATA[
import mx.collections.ArrayCollection;
//note that for this example to work, the dataprovider
//must be an array collection
[Bindable]
private var dp:ArrayCollection = new ArrayCollection([{name:"John Smith" ,position:"developer" }
, {name:"Ellen Smith" , position:"manager" }
, {name:"James Smith" , position:"accountant" }
, {name:"Jane Smith" , position:"designer" }]);
private function addItem():void {
dp.addItem({name:"Jim Smith" , position:"Janitor" });
}

]]>
</mx:Script>
<mx:DefaultListEffect color="0xccccfffadeOutDuration="2000"
id="glow"/>

<mx:List width="300itemsChangeEffect="{glow}"
dataProvider="{dp}editable="truelabelField="name"/>

<mx:Button click="addItem()label="add item"/>
<mx:List width="300itemsChangeEffect="{glow}"
dataProvider="{dp}editable="truelabelField="name"/>

</mx:VBox>
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表