2012-06-08 18 views
10

Ho una griglia che dovrebbe eseguire un renderer su una colonna, ma che non mostra nulla e non rintraccia la registrazione.ExtJS 4 "renderer" colonna sulla griglia

View

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 

    }  
}); 

Grazie

risposta

24

Il record non sta registrando correttamente lì perché la funzione di rendering ha parametri diversi da quelli che si sta tentando di utilizzare. Da http://docs.sencha.com/ext-js/4-1/#!/api/Ext.grid.column.Column-cfg-renderer:

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

Si sono, inoltre, non restituire il valore da dentro il renderer. Questo risolve questi due problemi:

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

Così buono !. Il problema era il RITORNO e l'ordine dei parametri. Molte grazie. – richardhell

Problemi correlati