Flex中List自己定义itemrenderer渲染问题的解决
来源:互联网 发布:mac如何装office 编辑:程序博客网 时间:2024/06/05 10:38
我们经常需要在List组件中自定义itemrenderer来满足我们同时显示多种内容的要求。比如增加一个CheckBox,这个在itemrenderer里实现很容易。
代码如下:
<?xml version="1.0" encoding="utf-8"?><s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600"><s:layout><s:BasicLayout/></s:layout><fx:Declarations><!-- 将非可视元素(例如服务、值对象)放在此处 --></fx:Declarations><fx:Script><![CDATA[import mx.collections.ArrayCollection;import mx.events.FlexEvent;[Bindable]private var dataArr:ArrayCollection = new ArrayCollection([{id:0,label:"西瓜"},{id:1,label:"黄瓜"},{id:2,label:"土豆"},{id:3,label:"南瓜"},{id:4,label:"西红柿"},{id:5,label:"韭菜"},{id:6,label:"辣椒"}]);]]></fx:Script><s:List x="90" y="51" width="161" height="71" dataProvider="{dataArr}"itemRenderer="ListItemRenderer" ></s:List></s:Application>
<?xml version="1.0" encoding="utf-8"?><s:ItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx" autoDrawBackground="true"> <s:layout> <s:HorizontalLayout verticalAlign="middle"/> </s:layout> <s:CheckBox id="ck" selected="{data.ck}" x="0" y="0"/> <s:Label text="{itemIndex}"/> <s:Label text="{data.label}"/> </s:ItemRenderer>
但有个问题,当我们对List进行数据绑定后,如果数据太多,就会出现滚动条。这时,如果我们选中了第一个CheckBox,如果拖支滚动条的时候,下面的某个项的CheckBox也会被选中。
在网上搜了一些结果后,估计原因是List在滚动的时候,会重用原有的对象,而不是新建。解决办法如下:
在绑定数组对象里加一个Boolean类型的变量,下面为ck
<?xml version="1.0" encoding="utf-8"?><s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600"><s:layout><s:BasicLayout/></s:layout><fx:Declarations><!-- 将非可视元素(例如服务、值对象)放在此处 --></fx:Declarations><fx:Script><![CDATA[import mx.collections.ArrayCollection;import mx.events.FlexEvent;[Bindable]private var dataArr:ArrayCollection = new ArrayCollection([{id:0,label:"西瓜",ck:true},{id:1,label:"黄瓜",ck:false},{id:2,label:"土豆",ck:false},{id:3,label:"南瓜",ck:false},{id:4,label:"西红柿",ck:false},{id:5,label:"韭菜",ck:false},{id:6,label:"辣椒",ck:false}]);]]></fx:Script><s:List x="90" y="51" width="161" height="71" dataProvider="{dataArr}"itemRenderer="ListItemRenderer" ></s:List></s:Application>
同时,在ItemRenderer中处理一下CheckBox的数据改变事件
<?xml version="1.0" encoding="utf-8"?><s:ItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx" autoDrawBackground="true"><s:layout><s:HorizontalLayout verticalAlign="middle"/></s:layout><fx:Script><![CDATA[import mx.events.FlexEvent;protected function changeHandler(event:Event):void{data.ck = ck.selected;}]]></fx:Script><s:CheckBox id="ck" selected="{data.ck}" x="0" y="0" change="changeHandler(event)"/><s:Label text="{itemIndex}"/><s:Label text="{data.label}"/></s:ItemRenderer>
阅读全文
0 0
- Flex中List自己定义itemrenderer渲染问题的解决
- 访问List的itemRenderer的组件中定义的方法
- Flex组件的项目渲染器(ItemRenderer)使用总结
- Flex组件的项目渲染器(ItemRenderer)使用总结
- Flex组件的项目渲染器(ItemRenderer)使用总结 收藏
- Flex组件的项目渲染器(ItemRenderer)使用总结
- Flex组件的项目渲染器(ItemRenderer)使用总结
- Flex组件的项目渲染器(ItemRenderer)使用总结
- Flex组件的项目渲染器(ItemRenderer)使用总结
- Flex组件的项目渲染器(ItemRenderer)使用总结
- Flex List 用嵌入的ItemRenderer实现CheckBox选中功能
- 理解Flex itemRenderer(1)--内联渲染器
- 理解Flex itemRenderer(2)--外部渲染器
- 理解Flex itemRenderer 1 内联渲染器
- Flex中自定义组件ItemRenderer,数据绑定dataprovider,刷新问题。
- flex的Datagrid的itemRenderer问题:奇葩的现象!
- Flex中itemRenderer效率解说
- 在FLEX的DATAGIRD中使用itemRenderer的一点心得
- ALGO-79删除数组零元素
- 2018 年你需要知道的 Vue.js 组件库,完善你的应用开发
- ALGO-81动态数组使用
- android——本地相机上传头像
- VB机房收费系统05——一般用户模块逻辑问题总结
- Flex中List自己定义itemrenderer渲染问题的解决
- Backbone.js 显示Collection里面的一个元素
- Spring AOP详解
- android jni 将BYTE* 和 jbyteArray 之间的转换
- Sublime Text 3 全程详细图文使用教程
- 多条目展示+视频播放
- AMP对发布商和电子商务的总体经济影响力
- lxc常见命令
- DIY申请PHD