
flex datagrid 自定义排序的问题
<?xmlversion="1.0"encoding="utf-8"?><mx:Applicationxmlns:mx="http://www.adobe.com/200...
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
creationComplete="init()">
<mx:Script>
<![CDATA[
import mx.utils.ObjectUtil;
private function init():void{
var ary:Array = new Array();
ary.push({col1:"123",col2:"99",col3:"ccc"});
ary.push({col1:"1001",col2:"121",col3:"eee"});
ary.push({col1:"121",col2:"1001",col3:"aaaa"});
ary.push({col1:"99",col2:"123",col3:"cccc"});
grid.dataProvider = ary;
}
//自定义排序方法,比较的结果为1(v1>v2),0(v1=v2),-1(v1<v2)
private function sortTest(v1:Object,v2:Object):int{
var i1:int = int(v1.aaa);
var i2:int = int(v2.aaa);
return ObjectUtil.numericCompare(i1,i2);
}
]]>
</mx:Script>
<mx:DataGrid id="grid" x="33" y="72">
<mx:columns>
<mx:DataGridColumn headerText="Column 1" dataField="aaa" sortCompareFunction="sortTest"/>
<mx:DataGridColumn headerText="Column 2" dataField="bbb" sortCompareFunction="sortTest"/>
<mx:DataGridColumn headerText="Column 3" dataField="ccc"/>
</mx:columns>
</mx:DataGrid>
</mx:Application>
现在有上面一个程序,需要每一列的数字都按照数值大小而不是字符的大小来排序,目前这种写法只能实现单列的排序,其他列都要排序的话就要重复写几乎相同的代码,不同的地方只是sortTest函数里面的v1.aaa和v2.aaa,请问有什么办法能够动态读取当前选择的datagrid的那个dataProvider的名字呢??
谢谢
最好能够是动态读取“aaa”这个值,
var i1:int = int(v1.aaa);
var i2:int = int(v2.aaa);
毕竟个人觉得这个代码还是比较简洁的,就是aaa那个问题比较困扰,谢谢了哦~ 展开
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
creationComplete="init()">
<mx:Script>
<![CDATA[
import mx.utils.ObjectUtil;
private function init():void{
var ary:Array = new Array();
ary.push({col1:"123",col2:"99",col3:"ccc"});
ary.push({col1:"1001",col2:"121",col3:"eee"});
ary.push({col1:"121",col2:"1001",col3:"aaaa"});
ary.push({col1:"99",col2:"123",col3:"cccc"});
grid.dataProvider = ary;
}
//自定义排序方法,比较的结果为1(v1>v2),0(v1=v2),-1(v1<v2)
private function sortTest(v1:Object,v2:Object):int{
var i1:int = int(v1.aaa);
var i2:int = int(v2.aaa);
return ObjectUtil.numericCompare(i1,i2);
}
]]>
</mx:Script>
<mx:DataGrid id="grid" x="33" y="72">
<mx:columns>
<mx:DataGridColumn headerText="Column 1" dataField="aaa" sortCompareFunction="sortTest"/>
<mx:DataGridColumn headerText="Column 2" dataField="bbb" sortCompareFunction="sortTest"/>
<mx:DataGridColumn headerText="Column 3" dataField="ccc"/>
</mx:columns>
</mx:DataGrid>
</mx:Application>
现在有上面一个程序,需要每一列的数字都按照数值大小而不是字符的大小来排序,目前这种写法只能实现单列的排序,其他列都要排序的话就要重复写几乎相同的代码,不同的地方只是sortTest函数里面的v1.aaa和v2.aaa,请问有什么办法能够动态读取当前选择的datagrid的那个dataProvider的名字呢??
谢谢
最好能够是动态读取“aaa”这个值,
var i1:int = int(v1.aaa);
var i2:int = int(v2.aaa);
毕竟个人觉得这个代码还是比较简洁的,就是aaa那个问题比较困扰,谢谢了哦~ 展开
5个回答
展开全部
我看了两遍你的问题!没看懂你要说的!
目前这种写法只能实现单列的排序,其他列都要排序。。。。
你要不就在绑定之前把ary排好了!
目前这种写法只能实现单列的排序,其他列都要排序。。。。
你要不就在绑定之前把ary排好了!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?

2022-08-05 广告
苏州蓝晓生物科技有限公司。标准化核心产品:公司拥有完整的琼脂糖介质、葡聚糖介质、聚甲基丙烯酸酯介质生产线,年产分离介质50000L,产品质量稳定并达到国际领先水平。核心优势:公司核心技术人员拥有近二十年不同基质的基球开发和官能化的丰富技术经...
点击进入详情页
本回答由苏州蓝晓生物科技有限公司_提供
展开全部
"需要每一列的数字都按照数值大小而不是字符的大小来排序"
按上面理解的话ary 元素的顺序是不是可以被打乱?
按上面理解的话ary 元素的顺序是不是可以被打乱?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2009-10-19
展开全部
跟JS一样,obj["属性名"]
像你的aaa就可以是obj["aaa"]
var prop="aaa";
obj[prop];
像你的aaa就可以是obj["aaa"]
var prop="aaa";
obj[prop];
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用headerRelease,然后函数在我的QQ空间,+我1257055386
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询