我试图弄清楚为什么当我将视图推送到 Ext.Navigation.View 控件时,我推送的视图会呈现,但我推送的数据却没有。该视图使用一些 json 数据(姓名和姓氏)呈现一个非常简单的 DataView 控件。
如果我通过“Ext.Create”显式创建视图(请参阅控制器中注释掉的行),它将起作用,但我确信我已经完成了此操作,您可以在其中推送视图的“xtype”和任何相关属性/数据视图。我对吗?
顺便说一句,我已经测试了从表单提交回调返回的 json,一切都很好。似乎视图不想呈现我发送的数据作为“推送”的一部分。这是我的代码。我错过了什么吗?:
看法:
Ext.define('MyCo.Booking.view.PatientClinicSearchResults', {
extend : 'Ext.DataView',
xtype : 'DataViewPatientSearchResults',
itemTpl : '{Name}',
store : {
fields : ['Name'],
autoLoad : true
}
})
控制器 :
Ext.define('MyCo.Booking.controller.Main', {
extend: 'Ext.app.Controller',
config: {
refs: {
navViewClinics : 'NavViewClinics',
formPanelClinicPatientSearch : 'FormPanelClinicPatientSearch'
},
control: {
'NavViewClinics list' : {
itemtap : 'ClinicUserSearch'
},
'FormPanelClinicPatientSearch button' : {
tap : 'ClinicPatientSearchResults'
}
}
},
ClinicUserSearch : function(list, index, element, record) {
this.getNavViewClinics().push({ xtype : 'FormPanelClinicPatientSearch' });
},
ClinicPatientSearchResults : function(button, e) {
var form = this.getFormPanelClinicPatientSearch();
var navClinics = this.getNavViewClinics();
form.submit({
success : function(form, result) {
// var view = Ext.create('MyCo.Booking.view.PatientClinicSearchResults', {
// title : 'Search Results',
// fullscreen: true,
// store: {
// fields: ['Name'],
// data : result.items
// },
// itemTpl: '<div>{Name}</div>'
// });
// navClinics.push(view);
navClinics.push({ xtype : "DataViewPatientSearchResults",
title : 'Test',
store : {
data : result.items
}
});
}
});
}
});
从表单提交回调收到的 JSON:
{
"success" : true,
"items" : [
{
"Name": "Jon",
"Surname": "Doe"
},
{
"Name": "Karl",
"Surname": "Doe"
}
]
}
任何帮助,将不胜感激。谢谢你。