2012-06-08 16 views
10

Mam siatkę, która powinna wykonać renderer w kolumnie, ale to nic nie pokazuje ani rekord recoignise.Kolumna ExtJS 4 "renderer" na siatce

Zobacz

Ext.define('Ab.view.maquina.MaquinaList', { 
    extend: 'Ext.grid.Panel', 
    alias: 'widget.maquinalist', 
    store: 'Maquinas', 
    tbar: [ 
     { text: _('Agregar'), action:'add'}, 
     { text: _('Editar'), action: 'upd'}, 
     { text: _('Eliminar'), action: 'del'} 
    ], 
    columns: [ 
     { text: _('Nombre'), flex: 1, dataIndex: 'nombre' }, 
     { text: _('Estado'), flex: 1, dataIndex: 'estado'}, 
     { text: _('Marca'), flex: 1, dataIndex: 'codigo', renderer: function(value, record){this.renderMarca(value, record)}} 
    ], 
    renderMarca: function(value,record){ 
      console.log(value); < show value 
      console.log(record.get('nombre')); < error 
      return value; < don't show value on the column 

    }  
}); 

Dzięki

Odpowiedz

24

Rekord nie loguje poprawnie tam ponieważ funkcja renderowania ma inne parametry niż te, które próbują wykorzystać. Od http://docs.sencha.com/ext-js/4-1/#!/api/Ext.grid.column.Column-cfg-renderer:

renderer: function (value, metaData, record, row, col, store, gridView) { 

Ty też nie zwracając wartość od wewnątrz renderujący. To rozwiązuje te dwa problemy:

{ 
    text: _('Marca'), 
    flex: 1, 
    dataIndex: 'codigo', 
    renderer: function(value, metaData, record, row, col, store, gridView){ 
    return this.renderMarca(value, record); 
    } 
} 
+0

Bardzo dobrze! Problemem był POWRÓT i kolejność paramów. Wielkie dzięki. – richardhell

Powiązane problemy