Flex4中Repeater和Flex3中HorizontalList的用法

目前,Flex4中已经Flex3中的HorizontalList组件替换为通用的List组件。

这里要注意他们的用法,像labelFunction方法,还有一个经常用的itemRenderer方法,该函数对应一个显示组件,使每一项数据对象对应一个组件。

还有一个就是Repeater 组件的用法。该示例中每一个数据对象对应一个RadioButton组件;使用currentItem赋值,  getRepeaterItem()用来从重复的组件中获取数据。此外常用的还有一个currentIndex

 

 

<?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:HorizontalLayout/>

    </s:layout>

    <fx:Style source="mycss.css">

      

    </fx:Style>

    <fx:Declarations>

       <!-- 将非可视元素(例如服务、值对象)放在此处 -->

    </fx:Declarations>

   

    <fx:Script>

       <![CDATA[

           import mx.collections.ArrayCollection;

           private var arrData:Array = [{name:"banana", cat:"fruit", cost:0.99},

                                       {name:"bread", cat:"bakery", cost:1.99},

                                       {name:"orange", cat:"fruit", cost:0.53}];

           [Bindable]  

           private var dp:ArrayCollection = new ArrayCollection(arrData);

          

           private function multiDisplay(item:Object):String

           {

              return item.cat + ": " + item.name + " $" + item.cost;

           }

       ]]>

    </fx:Script>

   

    <!-- Flex3中的HorizontalList组件用法, lableFunction  labelField,itemRenderer 等方法 -->

    <mx:HorizontalList dataProvider="{dp}" labelFunction="multiDisplay"/>

   

    <!-- List注意itemRenderer的用法, 其中MyVBox是自定义显示组件 ,这样每一个数据对象对应一个MyVBox组件   -->

    <s:List dataProvider="{dp}" itemRenderer="MyVBox"/>

   

    <!-- 下面介绍使用Repeater遍历数据集 -->

    <!-- click事件是从Repeater重复的组件中获取数据 -->

    <mx:Tile>

       <s:Label id="priceLabel" text="Price Here"/>

       <mx:Repeater id="myRepeator" dataProvider="{dp}">

           <s:RadioButton label="{myRepeator.currentItem.name}" click="priceLabel.text=event.target.getRepeaterItem().cost"/>

       </mx:Repeater>

    </mx:Tile>

</s:Application>

 

 

 

 

 

 

 

--MyVBox.mxml组件

<?xml version="1.0" encoding="utf-8"?>

<mx:VBox xmlns:fx="http://ns.adobe.com/mxml/2009"

        xmlns:s="library://ns.adobe.com/flex/spark"

        xmlns:mx="library://ns.adobe.com/flex/mx" width="46" height="18">

    <fx:Declarations>

       <!-- 将非可视元素(例如服务、值对象)放在此处 -->

    </fx:Declarations>

    <s:Label text="{data.name}" backgroundColor="0xff0ff000"/>

</mx:VBox>

 

 目前,Flex4中已经将Flex3中的HorizontalList

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值