FLEX实践—DATAGRID显示行号
短信预约 -IT技能 免费直播动态提醒
DataGrid自动显示行号,网上有很多做法可参考),我将它写成了一个控件。
DataGridLineNumTest.mxml
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
creationComplete="init()" xmlns:components="components.*">
<mx:Script>
<![CDATA[
import mx.collections.ArrayCollection;
private var dg:ArrayCollection = new ArrayCollection();
private function init():void{
var item:Object = {name:'A',code:'A1',price:'10'};
dg.addItem(item);
var item1:Object = {name:'B',code:'B1',price:'8'};
dg.addItem(item1);
var item2:Object = {name:'C',code:'C1',price:'3'};
dg.addItem(item2);
}
]]>
</mx:Script>
<mx:DataGrid x="318" y="71" width="525" height="318" dataProvider="{dg}">
<mx:columns>
<components:DataGridNumRender headerText="Line num" dataProvider="{dg}"/>
<mx:DataGridColumn headerText="Name" dataField="name"/>
<mx:DataGridColumn headerText="Code" dataField="code"/>
<mx:DataGridColumn headerText="Price" dataField="price"/>
</mx:columns>
</mx:DataGrid>
</mx:Application>
controls.DataGridNumRender.mxml (扩展DataGridColumn控件)
<?xml version="1.0" encoding="utf-8"?>
<mx:DataGridColumn xmlns:mx="http://www.adobe.com/2006/mxml" labelFunction="getLineNum">
<mx:Script>
<![CDATA[
import mx.collections.ArrayCollection;
public var dataProvider:ArrayCollection = new ArrayCollection();
public var index:Number;
private function getLineNum(item:Object,num:int):String{
index = dataProvider.getItemIndex(item)+1;
return String(index);
}
]]>
</mx:Script>
</mx:DataGridColumn>
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341