Свойство viewConfig должно указывать вам правильное направление - используя код из примера Ext для сетки, добавляя:
- cls поле для определения класса для записи
- viewConfig свойствок конфигурации сетки
Код выглядит так:
Ext.create('Ext.data.Store', {
storeId:'simpsonsStore',
fields:['name', 'email', 'phone', 'cls'],
data:{'items':[
{ 'name': 'Lisa', "email":"lisa@simpsons.com", "phone":"555-111-1224", "cls":"new-row" },
{ 'name': 'Bart', "email":"bart@simpsons.com", "phone":"555-222-1234", "cls":"new-row" },
{ 'name': 'Homer', "email":"home@simpsons.com", "phone":"555-222-1244", "cls":"new-row" },
{ 'name': 'Marge', "email":"marge@simpsons.com", "phone":"555-222-1254", "cls": "error-row" }
]},
proxy: {
type: 'memory',
reader: {
type: 'json',
root: 'items'
}
}
});
Ext.create('Ext.grid.Panel', {
title: 'Simpsons',
id: 'MyGrid',
store: Ext.data.StoreManager.lookup('simpsonsStore'),
columns: [
{ header: 'Name', dataIndex: 'name'},
{ header: 'Email', dataIndex: 'email', flex: 1},
{ header: 'Phone', dataIndex: 'phone'}
],
viewConfig: {
getRowClass: function(record, rowIndex, rowParams, store){
return record.get('cls');
}
},
height: 200,
width: 400,
renderTo: Ext.getBody()
});