繁体   English   中英

ExtJS4组合框加载/存储问题

[英]ExtJS4 combobox loading/store issue

我看到组合框有一个问题,其中有一个“更改”事件的侦听器。 事件触发时,它将运行一个函数,该函数过滤存储,该存储为另一个组合框供电,以过滤第二个组合框中可用的值。

这个想法是,当您从第一个组合框中的一个简短列表中进行选择时,它会缩减第二个组合框中的选择。

加载表单后,您可以单击第二个组合框并查看所有选择,效果很好。 然后,当您在第一个组合框中选择某个内容,然后再次单击第二个组合框时,您会看到相应的缩短列表,但该列表变灰,并且“正在加载...”的内容只会旋转,并且永远不会消失。

如果您加载表格并在第一个组合框中选择内容,然后单击第二个组合框,它将进行筛选并显示正常,但是如果您尝试在第一个组合框中更改选择并单击,则会遇到我上面描述的加载问题第二个组合框。

请查看下面的代码,该设置在其他屏幕上运行,并且似乎没有此问题。

我已经建立了一个ext商店,如下所示:

var comboBreaker = Ext.create('Ext.data.Store', {
    autoLoad: false,
    remoteSort: true,
    remoteFilter: true,
    fields: [{
        name: 'id',
        mapping: 'item_id',
        type: 'int',
        useNull: false},
        'item_display_number','item_name', 'line_item_type_id', 'item_description'
    ],
    proxy:{
        type:'ajax',
        url: '/invoicer/data/getlineitems',
        reader: {
            type: 'json',
            successProperty: 'success',
            root: 'results',
            totalProperty: 'totalCount'
        },
        sorters:[{
            property:'item_display_number',
            direction:'ASC'
        }]
    }
});

该存储为组合框供电,如下所示:

Ext.define('Writer.Form', {
    extend: 'Ext.form.Panel',
    alias: 'widget.writerform',

    requires: ['Ext.form.field.Text'],

    initComponent: function(){
        this.addEvents('create');
        Ext.apply(this, {
            activeRecord: null,
            frame: true,
            title: 'Line Item',
            id: 'writerform',
            fieldDefaults: {
                anchor: '100%',
                labelAlign: 'right'
            },
            items: [{
                xtype: 'combobox',
                fieldLabel: 'Item #',
                name: 'item_number',
                store: comboBreaker,
                displayField: 'item_display_number',
                valueField: 'id',
                allowBlank: false,
                forceSelection: true
            },{
                xtype: 'combobox',
                fieldLabel: 'Item Type',
                name: 'item_type',
                id: 'item_type',
                displayField: 'line_item_type',
                valueField: 'id',
                store: invoicer_lineItemTypeStore,
                forceSelection: true,
                labelWidth: 75,
                width: 200,
                listeners: {
                    change: {
                        fn: function() {
                            itemNumberFilter(comboBreaker);
                        }
                    }
                }
            }]
});

itemNumberFilter()函数接受一个存储并对其进行过滤,这是该代码:

function itemNumberFilter( store ) {
    var id = Ext.getCmp('item_type').getValue();
    store.remoteFilter = false;
    store.clearFilter();
    if ( id ) {

        store.filter('line_item_type_id', id);
    }
    store.remoteFilter = true;
    store.removeAll();
    store.load({
        scope: this,
        callback: function( records ) {
            console.log('Loaded records!');
            console.log(records);
        }
    });
}

每当我在第一个组合框中更改选择时,我都会看到已注销的记录,并且可以在第二个组合框中“看到”结果,但是它们始终显示为“正在加载。” GIF。

编辑:视频示例: http : //screencast.com/t/cUSHyFE6FIV

编辑:我相信这是解决方案:

lastQuery: '',
listeners: {
                        beforequery: {
                            fn: function(query) {
                                delete this.lastQuery;
                            }
                        }
                    }

将此添加到组合框配置可解决此问题。

Edit2:我遇到了由此引入的第二个错误,该错误通过添加以下内容得以修复:

this.clearValue();

到beforequery函数(删除this.lastQuery)。 每次单击下拉箭头都会清除组合框的值。

比方说,你选择项xcombo_1 ,然后项目a在削减下拉列表combo_2 然后,将combo_1的选择combo_1y ,然后将其再次更改为combo_2中的项目列表。 a在新的列表中提供combo_2 ,从选择项目导致ycombo_1 可能是当项目在组合列表中不再存在时尝试保持选中状态的问题。

在应用过滤器之前,您是否尝试过清除combo_2的选择?

您可以动态加载第二个combox框的存储,但是请确保将第二个combox框设置为“本地”。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM