首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Flex:关于DataGridColumn的sortCompareFunction的问题

Flex:关于DataGridColumn的sortCompareFunction的问题
EN

Stack Overflow用户
提问于 2010-08-10 16:44:52
回答 1查看 3.1K关注 0票数 2

无论如何,我可以对多列使用相同的sortCompareFunction,而不是为每列添加一个函数,因为我有一个包含50列的数据网格,其中40列的dataField不是string或number,它是一个数组,因此列的默认排序不起作用。根据adobe help的说法,sortCompareFunction的两个参数是整个数据提供程序元素,而不仅仅是项的数据,所以这意味着我必须定义40个排序函数,每个列一个。有没有其他的解决方案?

提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-08-10 18:49:40

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

代码语言:javascript
复制
<mx:DataGridColumn dataField="someFieldName"
    sortCompareFunction="{function(ob1:Object, obj2:Object):int{return mySortFunc(obj1, obj2, 'someFieldName');}}"/>

其中mySortFunc是这样实现的:

代码语言:javascript
复制
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);
    }
}

这样,您就可以使用一个函数来满足您的所有排序需求:)。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3447279

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档