For instance:
var data = {
name: 'Don Griffin',
kids: [
{ name: 'Aubrey', age: 17 },
{ name: 'Joshua', age: 13 },
{ name: 'Cale', age: 10 },
{ name: 'Nikol', age: 5 },
{ name: 'Solomon', age: 0 }
]
},
tpl = new Ext.XTemplate(
'<p>Name: {name}</p>',
'<p>Kids: ',
'<tpl for="kids">',
' <p',
'<tpl if="age > 1"> class="red"</tpl>',
'>{name}</p>',
'</tpl></p>');
tpl.overwrite(Ext.getBody(), data);
http://jsfiddle.net/L2dSX/
Or you can use the function:
tpl = new Ext.XTemplate(
'<p>Name: {name}</p>',
'<p>Kids: ',
'<tpl for="kids">',
' <p class="{[this.getKidClass(values)]}">{name}</p>',
'</tpl></p>',
{
getKidClass: function(kid){
debugger;
return kid.age > 1 ? 'red' : '';
}
}
);
http://jsfiddle.net/Cu85J/
source
share