在ExtJs 4.2.2上我需要覆盖某些列的默认排序器,并按绝对值(Math.abs)进行排序。
当我调试它时,我进入doSort()并获得正确的商店&方向(asc,desc),但由于某种原因它不执行rthe sorterFn() - 并运行默认的排序器(我知道它会导致没有任何内容打印到控制台,并且客户端中的行为是默认的)
{
itemId: someId,
//header: 'Abs. Change',
menuDisabled: false,
dataIndex: 'AbsChange',
sortable: true,
renderer: this.absChangeLabelRenderer,
width: 95,
align: 'right',
doSort: function (state) {
debugger;
var ds = this.up('tablepanel').store;
var field = this.getSortParam();
ds.sort({
property: field,
direction: state,
sorterFn: function (v1, v2) {
debugger;
console.log("value1 is {0}, value2 is {1}", v1, v2);
debugger;
v1 = Math.abs(v1.get(field));
v2 = Math.abs(v2.get(field));
// transform v1 and v2 here
return v1 > v2 ? 1 : (v1 < v2 ? -1 : 0);
}
});
}
}
答案 0 :(得分:1)
您应该在模型的字段定义中使用sortType
配置,即返回用于排序的值的函数。
示例配置:
fields: [
// ... other fields ...
{
name: 'AbsChange',
sortType: function(value) {
return Math.abs(value);
}
}
]