无论如何我可以为多列使用相同的sortCompareFunction而不是为每列添加一个函数,因为我有一个50列的datagrid,其中40列的dataField不是字符串或数字,它是一个数组,所以列的默认排序将不起作用。并根据adobe帮助sortCompareFunction的两个参数 是整个数据提供者元素而不仅仅是项目的数据,因此这意味着我必须为每列定义40个排序函数。还有其他解决方案吗?
提前致谢。
答案 0 :(得分:5)
您可以指定类似的排序函数:
<mx:DataGridColumn dataField="someFieldName"
sortCompareFunction="{function(ob1:Object, obj2:Object):int{return mySortFunc(obj1, obj2, 'someFieldName');}}"/>
其中mySortFunc的实现方式如下:
private function mySortFunc(obj1:Object, obj2:Object, fieldName:String):int{
if (obj1.hasOwnProperty(fieldName) && obj2.hasOwnProperty(fieldName)){
//comparison logic ex.
return obj1[fieldName]>obj2[fieldName]?1:(obj1[fieldName]<obj2[fieldName]?-1:0);
}
}
通过这种方式,您可以拥有一个满足所有排序需求的功能:)。