Flex:关于DataGridColumn的sortCompareFunction的问题

Yas*_*ine 2 apache-flex

无论如何我可以为多列使用相同的sortCompareFunction而不是为每列添加一个函数,因为我有一个50列的datagrid,其中40列的dataField不是字符串或数字,它是一个数组,所以默认排序为该列不起作用.根据adobe help,sortCompareFunction的两个参数是整个数据提供程序元素,而不仅仅是项目的数据,因此这意味着我必须为每列定义40个排序函数.还有其他解决方案吗?

提前致谢.

2DH*_*2DH 5

您可以像这样指定排序函数:

<mx:DataGridColumn dataField="someFieldName"
    sortCompareFunction="{function(ob1:Object, obj2:Object):int{return mySortFunc(obj1, obj2, 'someFieldName');}}"/>
Run Code Online (Sandbox Code Playgroud)

其中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);
    }
}
Run Code Online (Sandbox Code Playgroud)

这样你就可以有一个功能满足你所​​有的排序需求:).