Flex 学习笔记3

Flex 学习笔记3
 

15.项呈现器创建方法:

    1)内投方法:通过在列表控件的itemRenderer属性中定义单个组件,能够将插入的单个组件作为项呈现器

    2)内联方法:使用列表控件的子标签来定义一个或多个组件,这些组件将作为项呈现器

    3)可重用组件:将自定义组件作为项呈现器

内投方法示例:

    

<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml">

 <mx:Script>

 <![CDATA[

  

   [Bindable]

   privatevar myDP:Array = [

    {label: "Customer 1", selected: true},

    {label: "Customer 2", selected: false}

   ];

  

 ]]>

 </mx:Script>

 

 <mx:DataGrid dataProvider="{myDP}">

 <mx:columns>

   <mx:DataGridColumn dataField="label" headerText="Label" />

   <mx:DataGridColumn dataField="selected" itemRenderer="mx.controls.CheckBox" />

 </mx:columns>

 </mx:DataGrid>

 

</mx:Application>

内联方法示例:

<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml">

 <mx:Script>

 <![CDATA[

  

   [Bindable]

   privatevar myDP:Array = [

    {label: "Customer 1", selected: true},

    {label: "Customer 2", selected: false}

   ];

  

 ]]>

 </mx:Script>

 

 <mx:DataGrid dataProvider="{myDP}">

 <mx:columns>

   <mx:DataGridColumn dataField="label" headerText="Label" />

   <mx:DataGridColumn dataField="selected">

    <mx:itemRenderer>

     <mx:Component>

      <mx:VBox verticalAlign="middle" horizontalAlign="center">

       <mx:CheckBox/>

      </mx:VBox>

     </mx:Component>

    </mx:itemRenderer>

   </mx:DataGridColumn>

 </mx:columns>

 </mx:DataGrid>

</mx:Application>

将组件作为呈现器示例:

<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml">

 <mx:Script>

 <![CDATA[

  

   [Bindable]

   privatevar myDP:Array = [

    {label: "Oranges", date: new Date()},

    {label: "Apples", date: new Date()},

    {label: "Pears", date: new Date()}

   ];

  

 ]]>

 </mx:Script>

 

 <mx:List dataProvider="{myDP}" itemRenderer="MyCustomItemRenderer" />

 

</mx:Application>

MyCustomItemRenderer.xml

<mx:HBox xmlns:mx="http://www.adobe.com/2006/mxml">

 

 <mx:Script>

 <![CDATA[

   import mx.controls.Alert;

 ]]>

 </mx:Script>

 

 <mx:HBox>

 <mx:TextInput text="{data.label}" />

 <mx:DateField id="dateField" selectedDate="{data.date}" />

 <mx:Button label="Button" click="Alert.show('Selected item - Fruit: ' + data.label + '"n' + 'Date: ' + dateField.selectedDate)" />

 </mx:HBox>

</mx:HBox>
16.项编辑器
编辑过程:
a) 用户利用鼠标按钮或者tab键激活单元格
b) 分派itemEditBeginning 事件,使用该事件能够禁用某特定单元格或者多个单元格的编辑功能
c) 分派itemEditBegin事件以便打开项编辑器,该事件可用于修改传递给项编辑器数据
d)用户编辑单元格数据
e)用户移除焦点时,结束编辑会话
f)分派itemEditEnd 事件以便关闭项编辑器,同时使用新数据更新单元格

当列表控件(List Tree DataGrid)的editable属性设置为true时,用户就能够编辑控件内容

自定义编辑事件监听器访问单元格数据:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml">

 <mx:Script>
  <![CDATA[
   import mx.controls.TextInput;
   import mx.events.DataGridEvent;
   import mx.collections.ArrayCollection;
   
   [Bindable]
   private var productsAC:ArrayCollection = new ArrayCollection
   (
    [
     {Product: "iPod", Price: 249},
     {Product: "iMac", Price: 1299},
     {Product: "MacBook Pro", Price: 1999}
    ]
   );
   
   private function getCellInfo(event:DataGridEvent):void
   {
    var myEditor:TextInput = TextInput(event.currentTarget.itemEditorInstance);
    var newVal:String = myEditor.text;
    var oldVal:String = event.currentTarget.editedItemRenderer.data[event.dataField];
    cellInfo.text = "cell edited. \n";
    cellInfo.text += "Row, column: " + event.rowIndex + ", " + event.columnIndex + "\n";
    cellInfo.text += "New value: " + newVal + "\n";
    cellInfo.text += "Old value: " + oldVal;
   }
   
  ]]>
 </mx:Script>
 
 <mx:TextArea id="cellInfo" width="300" height="150" />
 
 <mx:DataGrid dataProvider="{productsAC}" editable="true" itemEditEnd="getCellInfo(event)">
  <mx:columns>
   <mx:DataGridColumn dataField="Product" />
   <mx:DataGridColumn dataField="Price" />
  </mx:columns>
 </mx:DataGrid>
 
</mx:Application>
禁用单元格编辑器:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml">

 <mx:Script>
  <![CDATA[
   import mx.controls.TextInput;
   import mx.events.DataGridEvent;
   import mx.collections.ArrayCollection;
   
   [Bindable]
   private var productsAC:ArrayCollection = new ArrayCollection
   (
    [
     {Product: "iPod", Price: 249},
     {Product: "iMac", Price: 1299},
     {Product: "MacBook Pro", Price: 1999}
    ]
   );
   
   private function onEditBeginning(event:DataGridEvent):void
   {
    if (event.rowIndex == 2)
     event.preventDefault();
   }
   
  ]]>
 </mx:Script>
 
 <mx:DataGrid dataProvider="{productsAC}" editable="true" itemEditBeginning="onEditBeginning(event)">
  <mx:columns>
   <mx:DataGridColumn dataField="Product" />
   <mx:DataGridColumn dataField="Price" />
  </mx:columns>
 </mx:DataGrid>
 
</mx:Application>



你可能感兴趣的:(Flex 学习笔记3)