Extjs 6 - 使用组合框过滤网格

时间:2016-09-30 10:46:34

标签: javascript extjs combobox

我想用一个组合框对我的网格进行排序,我希望当我在组合框中选择一个值时,网格的内容更改,例如type,任何人都可以帮助我吗?感谢

这是我的代码片段:

Ext.create('Ext.grid.Panel', {
    height: 400,
    title: 'Simpsons',
    store: pagingStore,
    columns: [{
            text: 'Name',
            dataIndex: 'name'
        }, {
            text: 'Email',
            dataIndex: 'email'
        }, {
            text: 'Phone',
            dataIndex: 'phone'
        },
        {
            text: 'Type',
            dataIndex: 'type'
        }],
    bbar: {
        xtype: 'pagingtoolbar',
        store: pagingStore,
        displayInfo: true,
        items: [
            '-', {
                xtype: 'combo',
                fieldLabel: 'List account',
                labelAlign: 'right',
                store: storeCombo,
                displayField: 'name'
            }]
    },
    renderTo: Ext.getBody()
});

1 个答案:

答案 0 :(得分:1)

你可能想要这样的东西:

Ext.create('Ext.grid.Panel', {
    height: 400,
    title: 'Simpsons',
    store: {
        fields: ['name', 'email', 'phone', 'type'],
        data: [{
            name: 'Homer',
            email: 'homer@simpsons.com',
            phone: '111-222-333',
            type: 'Foo'
        }, {
            name: 'Marge',
            email: 'marge@simpsons.com',
            phone: '111-222-334',
            type: 'Foo'
        }, {
            name: 'Bart',
            email: 'bart@simpsons.com',
            phone: '111-222-335',
            type: 'Bar'
        }, {
            name: 'Lisa',
            email: 'lisa@simpsons.com',
            phone: '111-222-336',
            type: 'Bar'
        }]
    },
    columns: [{
        text: 'Name',
        dataIndex: 'name'
    }, {
        text: 'Email',
        dataIndex: 'email'
    }, {
        text: 'Phone',
        dataIndex: 'phone'
    }, {
        text: 'Type',
        dataIndex: 'type'
    }],
    bbar: {
        xtype: 'toolbar',
        items: [
            '-', {
                xtype: 'combo',
                fieldLabel: 'List account',
                labelAlign: 'right',
                forceSelection: true,
                emptyText: '-- Select --',
                store: {
                    fields: ['type'],
                    data: [{
                        type: 'Foo'
                    }, {
                        type: 'Bar'
                    }]
                },
                displayField: 'type',
                valueField: 'type',
                listeners: {
                    change: function(combo, value) {
                        var grid = this.up('grid'),
                            store = grid.getStore();

                        if (!value) {
                            store.getFilters().removeAll();
                        } else {
                            store.filter([{
                                property: 'type',
                                value: value
                            }]);
                        }
                    }
                }
            }
        ]
    },
    renderTo: Ext.getBody()
});

https://fiddle.sencha.com/#fiddle/1hn4