I'm trying to load 'nested' data in a hasMany
relation in ExtJS4.
My model looks like this:
Ext.define("Entrypage.model.Entrypage",{
extend: "Ext.data.Model",
fields: ['id','title','urlkey','text','picture','keywords', 'searchterms','description','critriamodus'],
hasMany: {model: 'EntrypageCriterium',name:'brands'},
proxy: {
type: 'ajax',
url: '/Admin/extjson/entrypages',
reader: {type:'json', root:'entrypages'}
}
});
And EntrypageCriterium
:
Ext.define("Entrypage.model.EntrypageCriterium",{
extend: "Ext.data.Model",
fields: ['id','type','title']
});
I load my data like so:
Entrypage.load("nikon-coolpix",{success:function(record,options,success){
console.log(record);
}});
It loads fine. Json returns this:
{
"success": true,
"entrypages":[{
"id":"1",
"urlkey":"nikon-coolpix",
"title":"Nikon Coolpix",
"text":"Some blahblah about Nikon",
"keywords":"nikon,coolpix,digitale,camera",
"description":"Nikon Coolpix camera's",
"picture":"Nikon Coolpix camera's",
"searchterms":"nikon coolpix",
"language":"nl",
"brands":[
{"id":27038,"title":"Nikon","type":"brand"}
]
}]
}
But when I try record.brands()
or anything like that. It says no such method exists.
I think something is going wrong in mapping the data in the model.
Any helpy would be very much appreciated!
Finally found the problem. For any future reference:
If you're using packages in the new MVC structure of ExtJS, define the full path to the linked class in your association like so:
hasMany: {model: 'Entrypage.model.EntrypageCriterium', name: 'brands', associationKey:'brands'}
You need to set the associationKey property in the hasMany association, so it knows which json property to use.
hasMany: {model: 'EntrypageCriterium',name:'brands', associationKey:'brands'}
see the Loading Nested Data section here:
http://docs.sencha.com/ext-js/4-0/#!/api/Ext.data.reader.Reader
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With