Extjs 4.2.2 - 运行默认排序器逻辑而不是自定义排序器

时间:2015-05-27 13:55:21

标签: sorting extjs datagrid extjs4.2

在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);
                    }
                });
            }               
        }

1 个答案:

答案 0 :(得分:1)

您应该在模型的字段定义中使用sortType配置,即返回用于排序的值的函数。

示例配置:

fields: [
    // ... other fields ...
    {
        name: 'AbsChange',
        sortType: function(value) {
            return Math.abs(value);
        }
    }
]