我尝试了一些不同的东西但是我无法将数据从控制器传递到视图(到容器内的组件)。
我在这里查看了ServisDetail.js:
Ext.define('Asistan.view.ServisDetail', {
extend: 'Ext.Container',
xtype: 'servisDetail',
config: {
layout: 'fit',
items : [
{
xclass : 'Asistan.view.ServisToolbar'
},
{
// "data: {}" is needed to work. I try to pass data from controller to here
xtype: 'component',
tpl: Ext.create('Ext.XTemplate','{URUN_CIHAZ_ADI} jkjk')
}
]
}
});
这是我的控制器Servis.js,我认为认为它应该有效。但它没有传递数据:
Ext.define('Asistan.controller.Servis', {
extend: 'Ext.app.Controller',
config: {
refs: {
servis: 'servisNavigationView servisContainer list',
},
control: {
servis: {
itemdoubletap: 'showServis'
}
}
},
showServis: function(item, index, e, eOpts) {
this.servis = Ext.widget('servisDetail');
this.servis.config.items[1].data = eOpts.data; // <- Here! It doesn't work. console.log shows that the data is there but in the browser the data doesn't show up.
console.log(this.servis.config.items[1].data); // I can see my data here, right before the push
item.up('servisNavigationView').push(this.servis);
}
});
我缺少什么?
答案 0 :(得分:1)
尝试使用
showServis: function(item, index, e, eOpts) {
this.servis = Ext.widget('servisDetail');
this.servis.setData(eOpts.data); // setData applies the data to the container template.
item.up('servisNavigationView').push(this.servis);
}
答案 1 :(得分:0)
tpl
项应该有id
。
{
id: 'itemWithTpl', // <- here
xtype: 'component',
tpl: Ext.create('Ext.XTemplate','{URUN_CIHAZ_ADI} jkjk')
}
控制器:
showServis: function(item, index, target, record, e, eOpts) {
this.servis = Ext.widget('servisDetail');
item.up('servisNavigationView').push(this.servis);
Ext.getCmp('itemWithTpl').setData(record.data); // <- here
}