我试图在Flex3中创建一个动态数据网格,我有一个列的列表,一个对象的列表,这些对象对应于我从url获取的那些列的数据点。虽然网格工作得很好,但问题是列的排序是按词法顺序进行的。
我知道这可以通过向列添加sortcomparefunction来修复,这在这种情况下并不容易。我试着去做
var dgc:DataGridColumn = new DataGridColumn(dtf);
f1[dtf] = function(obj1:Object, obj2:Object):int {
return Comparators.sortNumeric(obj1[dtf],obj2[dtf]);
};
dgc.sortCompareFunction = f1[dtf];`但问题是,我在这里创建的函数对象在每次迭代中都会被覆盖(因为我正在添加列),最终所有列都将只对添加的最后一列进行排序。
请给我一些建议。
发布于 2010-10-19 20:06:49
假设您有一些对象的dynamicColumns数组,您想要从中创建数据网格列。
var columns:Array = new Array();
for (var i:int = 0; i < dynamicColumns.length; i++) {
var column:DataGridColumn = new DataGridColumn(dynamicColumns[i].label);
var dataGridColumnSortingHelper:DataGridColumnSortingHelper = new DataGridColumnSortingHelper(column);
column.sortCompareFunction = dataGridColumnSortingHelper.columnSortCompareFunction;
columns.push(column);
}
yourDataGrid.columns = columns;其中DataGridColumnSortingHelper是这样的:
public class DataGridColumnSortingHelper
{
private var column:DataGridColumn;
// Constructor
public function DataGridColumnSortingHelper(column:DataGridColumn)
{
this.column = column;
}
// Public Methods
public function columnSortCompareFunction(item1:Object, item2:Object):int
{
// define your custom function here and use column field to know what column you sorting by...
return 0;
}
}感谢Tom的评论。
https://stackoverflow.com/questions/2928248
复制相似问题