Вопрос

У меня проблема с настройкой RowExpander для моей сетки.Когда сетка визуализируется, расширитель уже открыт для каждой строки и внутри ничего нет.Когда я нажимаю на его значок, возникает следующая ошибка:nextBd имеет значение null.Я нашел очень похожую проблему здесь http://www.sencha.com/forum/showthread.php?185837-Grid-Panel-PlugIn-Rowexpander-nextBd-is-null но решение не работает для меня, и я до сих пор не понимаю, почему конфигурация плагина не может быть передана в методе initComponent:

Вот мой код сетки:



    Ext.define('GSIP.view.plans.PlanReqList' ,{
        extend: 'Ext.grid.Panel',
        alias : 'widget.gsip_devplan_list',
        id: 'gsip_plan_list',
        plugins: [{
            ptype: 'rowexpander',
            rowBodyTpl : [
                'Nazwa:{name}'
            ]
        }],
        //title:i18n.getMsg('gsip.view.PlanReqList.title'), 
        layout: 'fit',
        initComponent: function() {


            this.store = 'DevPlan';

    //      this.plugins = [{
    //            ptype: 'rowexpander',
    //            rowBodyTpl : [
    //                {name}
    //            ]
    //        }];

            this.features = [{ftype:'filters', encode:false, local:true},{ftype:'grouping'}];

            this.tbar = [{
                xtype:'commandbutton',
                id: 'newReq',
                iconCls:'icon-application_add',
                text: i18n.getMsg('gsip.view.plans.PlanReqList.addReq'),
                command: 'newReq',
            }];

            this.viewConfig = {
                forceFit:true,
                getRowClass: function(record, index) {
                    var c = record.get('elapsedPercent');
                    if (c >= 0) {                   
                        return 'elapsed-normal';
                    } 
                }
            }

            this.columns = [
                {header: "Id", dataIndex: "id", width:50, sortable: true, filter:{type:'numeric'}},
                {header: i18n.getMsg('gsip.view.plans.PlanReqList.column.name'), dataIndex: "name", flex:1, sortable: true, filter:{type:'string'} },

                }
            ];


            this.callParent(arguments);


        },

Это было полезно?

Решение

А rowexpander Плагин использует функцию под названием rowbody.

В вашей initComponent() ты отвергаешь this.features (который уже включает rowbody) с этой строкой:

this.features = [{ftype:'filters', encode:false, local:true},{ftype:'grouping'}];

Таким образом rowbody функция не включена;Таким образом .x-grid-rowbody-tr класс не внедряется;таким образом rowexpander не могу найти такой класс для nextBd и возвращает ноль.

Тебе стоит попробовать:

var iNewFeatures = [{ftype:'filters', encode:false, local:true},{ftype:'grouping'}];
this.features = iNewFeatures.concat( this.features );

Наконец, плагины не могут быть инициированы в InitComponent(), вы можете объявить их как конфигурации или внутри конструктора.Видеть эта тема для получения дополнительной информации.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top