1

我在使用组合框时遇到了数据排序问题。

数据源为 JSON。数据在sql中排序。结果集(在 sql 中)和 JSON 结果看起来不错:

{"rows":[{"id":"TOT","txt":" Alle diagnosen"},{"id":"612","txt":"(acute) bloeding distale tract. digestivus*"},{"id":"042","txt":"(auto)-intoxicatie"},{"id":"402","txt":"(benigne) peptisch ulcus*"},{"id":"10","txt":"(bij)niertumor"},{"id":"652","txt":"(chorio)retinitis.. etc etc

当我使用 firebug 检查商店时,结果数据看起来很好(=与 JSON 结果相同的排序顺序):

在此处输入图像描述

但是,生成的组合框有不同的(错误的)排序(前 2 个可以):

在此处输入图像描述

它不按显示值排序,也不按 id 值排序。任何地方都没有添加分拣机。

组合:

{
    xtype: 'combobox',
    id: 'ComboDiag',
    itemId: 'ComboDiag',
    width: 280,
    fieldStyle: '',
    name: 'ComboDiag',
    fieldLabel: 'Diagnose',
    labelWidth: 90,
    displayField: 'txt',
    queryMode: 'local',
    store: 'ComboDiagStore',
    typeAhead: true,
    valueField: 'id',
    listeners: {
        render: {
            fn: me.onComboDiagRender,
            scope: me
        }
    }
}

店铺:

Ext.define('AppPitDash.store.ComboDiagStore', {
    extend: 'Ext.data.Store',
    alias: 'store.ComboDiagStore',
    requires: [
        'AppPitDash.model.ComboDiagModel'
    ],

    constructor: function(cfg) {
        var me = this;
        cfg = cfg || {};
        me.callParent([Ext.apply({
            autoLoad: true,
            storeId: 'ComboDiagStore',
            model: 'AppPitDash.model.ComboDiagModel',
            proxy: {
                type: 'ajax',
                url: './php/get-data-diagCombo.php',
                reader: {
                    type: 'json',
                    root: 'rows'
                }
            }
        }, cfg)]);
    }
});

模型:

Ext.define('AppPitDash.model.ComboDiagModel', {
    extend: 'Ext.data.Model',

    fields: [
        {
            name: 'id'
        },
        {
            name: 'txt'
        }
    ]
});

我第一次使用 Sencha Architect 2。

这比令人讨厌的东西更令人烦恼,但仍将不胜感激。

4

2 回答 2

1

尝试在商店定义中添加方法remoteSort: truecallParent

于 2012-05-24T14:44:09.393 回答
0

尝试使用:

remoteGroup: true,
remoteSort: true, 
sortInfo: { field: 'order', direction: 'DESC' },
于 2012-05-24T15:57:55.967 回答