我正在将我的ExtJs3应用程序迁移到ExtJs4。
在ExtJs3中,我有一个树网格,它有一个加载器来加载树数据,如下所示:
loader: new Ext.tree.TreeLoader({
dataUrl: 'Department/DepartmentTree',
nestedRoot: 'Data.items'
})所以我尝试在ExtJs4中创建一个treeStore,如下所示:
var store = Ext.create('Ext.data.TreeStore', {
model: 'DepartmentTreeModel',
folderSort: true,
proxy: {
type: 'ajax',
url: 'Department/DepartmentTree',
reader: {
type: 'json',
root: 'Data.items'
}
}
});当我在上面的存储Cannot read property 'items' of undefined上调用load函数时,我得到一个错误。
JSON响应如下所示:
{
"Data":{
"__type":"ListWrapperOfDepartmentTreeNodewnEzJCii:#PortalMvc.Global.Classlibrary.Model.Ui.JSONWrappers",
"items":[{
"ActualHeadcount":0,
"Headcount":0,
"Leavers":0,
"ParentId":"~~",
"Starters":0,
"children":[{
"ActualHeadcount":0,
"Headcount":0,
"Leavers":0,
"ParentId":"!#",
"Starters":0,
"children":[{
"ActualHeadcount":0,
"Headcount":0,
"Leavers":0,
"ParentId":"*w",
"Starters":0,
"children":[{
"ActualHeadcount":0,
"Headcount":0,
"Leavers":0,
"ParentId":"*z",
"Starters":0,
"children":[],
"iconCls":"admin_button",
"id":"*{",
"leaf":true,
"text":"Parking1_subtree1"
}]
}]
}]
}]
}
}发布于 2011-06-07 22:22:35
它期望对每组子节点重复根。因此,对于“孩子”,它也试图读取"Data.items“。
如果你不能改变数据结构,根也可以是一个函数,如下所示:
root: function(o) {
if (o.Data) {
return o.Data.items;
} else {
return o.children;
}
}https://stackoverflow.com/questions/6263380
复制相似问题