好的,我按字母顺序对
XMLListCollection进行排序.我有一个问题.如果值为“ALL”,我希望它在列表中排在第一位.在大多数情况下,这种情况已经发生,但数字值正在“ALL”之前进行排序.我希望“ALL”始终是我的dataProvider中的第一个选择,然后按字母顺序排列.
所以我正在尝试编写自己的排序函数.有没有办法可以检查其中一个值是否全部,如果没有告诉它对值进行常规比较?
这是我有的:
function myCompare(a:Object,b:Object,fields:Array = null):int { if(String(a).toLowerCase() == 'all') { return -1; } else if(String(b).toLowerCase() == 'all') { return 1; } // NEED to return default comparison results here? } //------------------------------ var sort:Sort = new Sort(); sort.compareFunction = myCompare;
对于我想要做的事情,有没有解决方案?
解决方法
来自John Isaacks的解决方案很棒,但是他忘记了“fields”变量,他的例子不适用于更复杂的对象(除了字符串)
例:
// collection with custom objects. We want to sort them on "value" property // var item:CustomObject = new CustomObject(); // item.name = 'Test'; // item.value = 'Simple Value'; var collection:ArrayCollection = new ArrayCollection(); var s:Sort = new Sort(); s.fields = [new SortField("value")]; s.compareFunction = myCompare; collection.sort = s; collection.refresh(); private function myCompare(a:Object,fields:Array = null):int { if(String((a as CustomObject).value).toLowerCase() == 'all') { return -1; } else if(String((b as CustomObject).value).toLowerCase() == 'all') { return 1; } // NEED to return default comparison results here? var s:Sort = new Sort(); s.fields = fields; var f:Function = s.compareFunction; return f.call(null,a,b,fields); }