(十二)AdvancedDataGrid

AdvancedDataGrid扩展了普通的DataGrid,功能更强大
设置AdvancedDataGrid的样式
   关注特别的行、列或单元。常见用法:将负数显示为红色
   AdvancedDataGrid允许编写并调用样式函数以实现上述功能

1.使用styleFunction属性,指定一个函数,该函数返回一个样式规则
2.数据分组(使用标签或者ActionScript来实现),实际上是对dataProvider进行操作
3.提供摘要信息(使用标签或者ActionScript来实现),实际是对各分组数据的操作
(GroupingCollection2类描述的数据才能显示摘要信息)

1.AdvancedDataGrid排序功能
下面的代码执行后,将会呈现一个可滚动列表
用户点击标题可以设置第一排序,第二排序字段
排序功能由AdvancedDataGrid底层提供
<?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" >

	<s:layout>
		<s:VerticalLayout paddingTop="10"
						  horizontalAlign="center"/>
	</s:layout>

	<fx:Script>
		<![CDATA[
			import mx.collections.ArrayCollection;
	
			private var arrayData:Array=[
				{name:"banana",cat:"fruit",cost:.99,qty:2},
				{name:"bread",cat:"bakery",cost:1.99,qty:3},
				{name:"cheddar cheese",cat:"dairy",cost:4.52,qty:6},
				{name:"sour cream",cat:"dairy",cost:.33,qty:2},
				{name:"orange",cat:"fruit",cost:.52,qty:4},
				{name:"donut",cat:"bakery",cost:.33,qty:2},
				{name:"yogurt",cat:"dairy",cost:.99,qty:5},
				{name:"milk",cat:"dairy",cost:2.99,qty:2},
				{name:"apple",cat:"fruit",cost:1.05,qty:4},
				{name:"colby cheese",cat:"dairy",cost:3.05,qty:4}];
	
			[Bindable]
			private var dp:ArrayCollection=new ArrayCollection(arrayData);
		]]>
	</fx:Script>

	<mx:AdvancedDataGrid dataProvider="{dp}"
		height="250"/>

</s:Application>


sortExpertMode="true"
<?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" >

	<s:layout>
		<s:VerticalLayout paddingTop="10"
						  horizontalAlign="center"/>
	</s:layout>

	<fx:Script>
		<![CDATA[
			import mx.collections.ArrayCollection;
	
			private var arrayData:Array=[
				{name:"banana",cat:"fruit",cost:.99,qty:2},
				{name:"bread",cat:"bakery",cost:1.99,qty:3},
				{name:"cheddar cheese",cat:"dairy",cost:4.52,qty:6},
				{name:"sour cream",cat:"dairy",cost:.33,qty:2},
				{name:"orange",cat:"fruit",cost:.52,qty:4},
				{name:"donut",cat:"bakery",cost:.33,qty:2},
				{name:"yogurt",cat:"dairy",cost:.99,qty:5},
				{name:"milk",cat:"dairy",cost:2.99,qty:2},
				{name:"apple",cat:"fruit",cost:1.05,qty:4},
				{name:"colby cheese",cat:"dairy",cost:3.05,qty:4}];
	
			[Bindable]
			private var dp:ArrayCollection=new ArrayCollection(arrayData);
		]]>
	</fx:Script>
	
	<!-- 当指定sortExpertMode="true" 多排序区域将不会出现 
	     在此模式下若要进行多排序,需要使用ctrl再单击另外的排序列的标题区域-->
	<mx:AdvancedDataGrid dataProvider="{dp}"
		sortExpertMode="true"
		height="250"/>

</s:Application>


使用LabelFunction指定样式规则,通过函数返回样式
<?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" >

	<s:layout>
		<s:VerticalLayout paddingTop="10"
						  horizontalAlign="center"/>
	</s:layout>

	<fx:Script>
		<![CDATA[
			import mx.collections.ArrayCollection;
	
			private var arrayData:Array=[
				{name:"banana",cat:"fruit",cost:.99,qty:2},
				{name:"bread",cat:"bakery",cost:1.99,qty:3},
				{name:"cheddar cheese",cat:"dairy",cost:4.52,qty:6},
				{name:"sour cream",cat:"dairy",cost:.33,qty:2},
				{name:"orange",cat:"fruit",cost:.52,qty:4},
				{name:"donut",cat:"bakery",cost:.33,qty:2},
				{name:"yogurt",cat:"dairy",cost:.99,qty:5},
				{name:"milk",cat:"dairy",cost:2.99,qty:2},
				{name:"apple",cat:"fruit",cost:1.05,qty:4},
				{name:"colby cheese",cat:"dairy",cost:3.05,qty:4}];
	
			[Bindable]
			private var dp:ArrayCollection=new ArrayCollection(arrayData);

			public function myStyleFunc(data:Object,col:AdvancedDataGridColumn):Object
			{
				if(data["cost"]==0.99) {
					return {color:0xFF0000,fontWeight:"blod"};
				} else {
					return null;
				}
			}
		]]>
	</fx:Script>

	<mx:AdvancedDataGrid dataProvider="{dp}"
		height="250">
		<mx:columns>
			<mx:AdvancedDataGridColumn dataField="cat"/>
			<mx:AdvancedDataGridColumn dataField="name"/>
			<mx:AdvancedDataGridColumn dataField="cost" styleFunction="myStyleFunc"/> <!--styleFunction作用于局部 -->
		</mx:columns>
	</mx:AdvancedDataGrid>

</s:Application>


<?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" >

	<s:layout>
		<s:VerticalLayout paddingTop="10"
						  horizontalAlign="center"/>
	</s:layout>

	<fx:Script>
		<![CDATA[
			import mx.collections.ArrayCollection;
	
			private var arrayData:Array=[
				{name:"banana",cat:"fruit",cost:.99,qty:2},
				{name:"bread",cat:"bakery",cost:1.99,qty:3},
				{name:"cheddar cheese",cat:"dairy",cost:4.52,qty:6},
				{name:"sour cream",cat:"dairy",cost:.33,qty:2},
				{name:"orange",cat:"fruit",cost:.52,qty:4},
				{name:"donut",cat:"bakery",cost:.33,qty:2},
				{name:"yogurt",cat:"dairy",cost:.99,qty:5},
				{name:"milk",cat:"dairy",cost:2.99,qty:2},
				{name:"apple",cat:"fruit",cost:1.05,qty:4},
				{name:"colby cheese",cat:"dairy",cost:3.05,qty:4}];
	
			[Bindable]
			private var dp:ArrayCollection=new ArrayCollection(arrayData);
			
			//参数1:代表某列的数据
			//参数2:包括了sytleFunction属性对应的列的信息
			//返回值:null,表示不使用任何样式;
			//返回包含了若干样式属性及其对应值的Object
			//返回的样式将作用于AdvancedDataGrid的中,即字体颜色都被设为了红色
			public function myStyleFunction(data:Object,col:AdvancedDataGridColumn):Object {
				return {color:0xFF0000,fontWeight:"blod"};
			}
		]]>
	</fx:Script>

	<mx:AdvancedDataGrid dataProvider="{dp}"
		height="250"
		styleFunction="myStyleFunction"> <!-- 通过styleFunction属性指定对应函数,由函数返回样式规则-->
		<mx:columns>
			<mx:AdvancedDataGridColumn dataField="cat"/>
			<mx:AdvancedDataGridColumn dataField="name"/>
			<mx:AdvancedDataGridColumn dataField="cost"/>
		</mx:columns>
	</mx:AdvancedDataGrid>

</s:Application>


2.AdvancedDataGrid中对数据分组和增加摘要信息
通过标签完成:
<?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" >

	<s:layout>
		<s:VerticalLayout paddingTop="10"
						  horizontalAlign="center"/>
	</s:layout>

    <fx:Script>
        <![CDATA[
        	import mx.collections.ArrayCollection;
            
            private var arrayData:Array=[
                {name:"banana",cat:"fruit",cost:.99,qty:2},
                {name:"bread",cat:"bakery",cost:1.99,qty:3},
                {name:"cheddar cheese",cat:"dairy",cost:4.52,qty:6},
                {name:"sour cream",cat:"dairy",cost:.33,qty:2},
                {name:"orange",cat:"fruit",cost:.52,qty:4},
                {name:"donut",cat:"bakery",cost:.33,qty:2},
                {name:"yogurt",cat:"dairy",cost:.99,qty:5},
                {name:"milk",cat:"dairy",cost:2.99,qty:2},
                {name:"apple",cat:"fruit",cost:1.05,qty:4},
                {name:"colby cheese",cat:"dairy",cost:3.05,qty:4}];
    
            [Bindable]
            private var dp:ArrayCollection=new ArrayCollection(arrayData);
        ]]>
    </fx:Script>

    <mx:AdvancedDataGrid height="200"
						 creationComplete="myGroup.refresh()"> <!-- refresh被调用,程序就开始对数据进行分组,然后才能呈现-->
		<mx:dataProvider>
			<mx:GroupingCollection2 id="myGroup" source="{dp}">
				<mx:Grouping>
					<mx:GroupingField name="cat"/> <!--name属性指定了分组依据的字段,即按类别分组-->
				</mx:Grouping>
			</mx:GroupingCollection2>
		</mx:dataProvider>
		<mx:columns>
                  <mx:AdvancedDataGridColumn dataField="name"/>
                  <mx:AdvancedDataGridColumn dataField="cost"/>
                  <mx:AdvancedDataGridColumn dataField="qty"/>
            </mx:columns>
      </mx:AdvancedDataGrid>
 
 </s:Application>


<?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" >

	<s:layout>
		<s:VerticalLayout paddingTop="10"
						  horizontalAlign="center"/>
	</s:layout>

    <fx:Script>
        <![CDATA[
        	import mx.collections.ArrayCollection;
            
            private var arrayData:Array=[
                {name:"banana",cat:"fruit",cost:.99,qty:2},
                {name:"bread",cat:"bakery",cost:1.99,qty:3},
                {name:"cheddar cheese",cat:"dairy",cost:4.52,qty:6},
                {name:"sour cream",cat:"dairy",cost:.33,qty:2},
                {name:"orange",cat:"fruit",cost:.52,qty:4},
                {name:"donut",cat:"bakery",cost:.33,qty:2},
                {name:"yogurt",cat:"dairy",cost:.99,qty:5},
                {name:"milk",cat:"dairy",cost:2.99,qty:2},
                {name:"apple",cat:"fruit",cost:1.05,qty:4},
                {name:"colby cheese",cat:"dairy",cost:3.05,qty:4}];
    
            [Bindable]
            private var dp:ArrayCollection=new ArrayCollection(arrayData);
        ]]>
    </fx:Script>
	
	<!--设置AdvancedDataGrid的属性defaultLeafIcon="null" 可以移除物品签发的图标-->
	<mx:AdvancedDataGrid creationComplete="myGroup.refresh()"
		height="200" >
		<mx:dataProvider>
			<mx:GroupingCollection2 id="myGroup" source="{dp}">
				<mx:Grouping>
					<mx:GroupingField name="cat">
						<!-- 为各个分组创建摘要信息-->
						<mx:summaries>
							<mx:SummaryRow summaryPlacement="last">
								<mx:fields>
									<!--dataField计算摘要的数据字段 
									    summaryOperation定义了摘要数据如何计算:SUM MIN MAX AVG COUNT
									    label将摘要值关联到某个字段
									    -->
									<mx:SummaryField2 dataField="qty" summaryOperation="SUM" label="summary"/>
								</mx:fields>
							</mx:SummaryRow>
						</mx:summaries>
						
					</mx:GroupingField>
				</mx:Grouping>
			</mx:GroupingCollection2>
		</mx:dataProvider>
		<mx:columns>
              <mx:AdvancedDataGridColumn dataField="name"/>
              <mx:AdvancedDataGridColumn dataField="cost"/>
              <mx:AdvancedDataGridColumn dataField="qty"/>
        </mx:columns>
		
		<mx:rendererProviders>
			<!-- 本项目呈现器专用于summary字段
			     columnIndex属性使呈现器显示在索引为1的列中,列索引从0开始
			     columnSpan指定呈现器横跨几列
			     renderer指定呈现器的路径-->
			<mx:AdvancedDataGridRendererProvider dataField="summary" columnIndex="1" columnSpan="2" renderer="renderers.SummaryText"/>
		</mx:rendererProviders>
		
  </mx:AdvancedDataGrid>
 </s:Application>


SummaryText.mxml
<?xml version="1.0" encoding="utf-8"?>
<s:MXAdvancedDataGridItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009" 
								  xmlns:s="library://ns.adobe.com/flex/spark" 
								  xmlns:mx="library://ns.adobe.com/flex/mx" 
								  focusEnabled="true">
	<!-- data属性会包含表格中某一行的所有数据,Flex会自动将这些数据传递给组件-->
	<s:Label id="lblData" top="0" left="0" right="0" bottom="0" text="Total number of items:{data.summary}" />
</s:MXAdvancedDataGridItemRenderer>



通过ActionScript完成分组与添加摘要信息
<?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" >

	<s:layout>
		<s:VerticalLayout paddingTop="10"
						  horizontalAlign="center"/>
	</s:layout>

    <fx:Script>
        <![CDATA[
			import mx.collections.ArrayCollection;
			import mx.collections.Grouping;
			import mx.collections.GroupingCollection2;
			import mx.collections.GroupingField;
			
			import spark.components.Group;

            private var arrayData:Array=[
                {name:"banana",cat:"fruit",cost:.99,qty:2},
                {name:"bread",cat:"bakery",cost:1.99,qty:3},
                {name:"cheddar cheese",cat:"dairy",cost:4.52,qty:6},
                {name:"sour cream",cat:"dairy",cost:.33,qty:2},
                {name:"orange",cat:"fruit",cost:.52,qty:4},
                {name:"donut",cat:"bakery",cost:.33,qty:2},
                {name:"yogurt",cat:"dairy",cost:.99,qty:5},
                {name:"milk",cat:"dairy",cost:2.99,qty:2},
                {name:"apple",cat:"fruit",cost:1.05,qty:4},
                {name:"colby cheese",cat:"dairy",cost:3.05,qty:4}];
    
            [Bindable]
            private var dp:ArrayCollection=new ArrayCollection(arrayData);
           
			private function initDG():void
			{
				 //创建分组集合对象
				 var myGroupColl:GroupingCollection2 = new GroupingCollection2();
				 //获取dataProvider
				 myGroupColl.source = myADG.dataProvider;
				 
				 //创建分组
				 var group:Grouping = new Grouping();
				 //分组字段
				 var gf:GroupingField = new GroupingField("cat");
				 //以数组格式赋值到分组对象的fields属性中
				 group.fields = [gf];
				 //将分组对象赋值到分组集合的grouping属性中
				 myGroupColl.grouping = group;
				 
				 //调用refresh方法,对数据进行分组
				 myGroupColl.refresh();
				 
				 //将数据重新放回AdvancedDataGrid中
				 myADG.dataProvider = myGroupColl;
			}
        ]]>
    </fx:Script>

	<mx:AdvancedDataGrid id="myADG" 
	    dataProvider="{dp}"
		creationComplete="initDG()">
	    <mx:columns>
	        <mx:AdvancedDataGridColumn dataField="name"/>
	        <mx:AdvancedDataGridColumn dataField="cost"/>
	        <mx:AdvancedDataGridColumn dataField="qty"/>
	    </mx:columns>
	</mx:AdvancedDataGrid>

</s:Application>


<?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" >

	<s:layout>
		<s:VerticalLayout paddingTop="10"
						  horizontalAlign="center"/>
	</s:layout>

    <fx:Script>
        <![CDATA[
			import mx.collections.ArrayCollection;
			import mx.collections.Grouping;
			import mx.collections.GroupingCollection2;
			import mx.collections.GroupingField;
			import mx.collections.SummaryField2;
			import mx.collections.SummaryRow;

            private var arrayData:Array=[
                {name:"banana",cat:"fruit",cost:.99,qty:2},
                {name:"bread",cat:"bakery",cost:1.99,qty:3},
                {name:"cheddar cheese",cat:"dairy",cost:4.52,qty:6},
                {name:"sour cream",cat:"dairy",cost:.33,qty:2},
                {name:"orange",cat:"fruit",cost:.52,qty:4},
                {name:"donut",cat:"bakery",cost:.33,qty:2},
                {name:"yogurt",cat:"dairy",cost:.99,qty:5},
                {name:"milk",cat:"dairy",cost:2.99,qty:2},
                {name:"apple",cat:"fruit",cost:1.05,qty:4},
                {name:"colby cheese",cat:"dairy",cost:3.05,qty:4}];
    
            [Bindable]
            private var dp:ArrayCollection=new ArrayCollection(arrayData);
           
			 private function initDG():void
			{
				var myGroupColl:GroupingCollection2=new GroupingCollection2();
				myGroupColl.source=myADG.dataProvider;
				var group:Grouping=new Grouping();
				var gf:GroupingField=new GroupingField("cat");
				group.fields=[gf];
				myGroupColl.grouping=group;

				
				//创建摘要信息(逐一将各对象的属性进行设置,然后赋值到相应的对象上)
				var sr:SummaryRow = new SummaryRow();
				
				var sf:SummaryField2 = new SummaryField2();
				sf.dataField = "qty";
				sf.summaryOperation = "SUM";
				sf.label = "summary";
				
				sr.fields = [sf];
				sr.summaryPlacement = "last";
				
				gf.summaries = [sr];
				
				//配置好摘要信息后才调用refresh
				myGroupColl.refresh();
				myADG.dataProvider=myGroupColl;
			}
        ]]>
    </fx:Script>

	<mx:AdvancedDataGrid id="myADG" 
	    dataProvider="{dp}"
	    creationComplete="initDG()">
	    <mx:columns>
	        <mx:AdvancedDataGridColumn dataField="name"/>
	        <mx:AdvancedDataGridColumn dataField="cost"/>
	        <mx:AdvancedDataGridColumn dataField="qty"/>
	    </mx:columns>
		<mx:rendererProviders>
		    <mx:AdvancedDataGridRendererProvider 
		        dataField="summary"
		        columnIndex="1"
		        columnSpan="2"
		        renderer="renderers.SummaryTextForAS"/>
		</mx:rendererProviders>
	</mx:AdvancedDataGrid>

</s:Application>

SummaryTextForAS.mxml
<?xml version="1.0" encoding="utf-8"?>
<s:MXAdvancedDataGridItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009" 
								  xmlns:s="library://ns.adobe.com/flex/spark" 
								  xmlns:mx="library://ns.adobe.com/flex/mx" 
								  focusEnabled="true">
	<s:Label id="lblData" top="0" left="0" right="0" bottom="0" text="Total number of items: {data.summary}" />
</s:MXAdvancedDataGridItemRenderer>

你可能感兴趣的:(datagrid)