【发布时间】:2013-11-04 12:13:06
【问题描述】:
我有一个网格链接到带有autoLoad: true 的商店。问题是商店会在应用程序启动时加载,即使视图是稍后通过菜单访问时才创建的。
我已经在 Application.js 和视图中引用了商店,但我没有明确地实例化商店和视图。
我不知道如何实现仅在视图需要时才加载商店。
- 如果我设置
autoLoad: true,商店会在应用程序启动时加载。 - 如果我设置
autoLoad: false,则商店根本不会加载。
我知道这是非常基本的,但到目前为止我被困住了。
以下是所有相关代码供参考:
应用/商店/Owners.js
Ext.define('Mb.store.Owners', {
extend: 'Ext.data.Store',
model: 'Mb.model.Owner',
autoLoad: true,
proxy: {
...
});
应用程序.js
Ext.define('Mb.Application', {
name: 'Mb',
extend: 'Ext.app.Application',
models: [
'Owner'
],
stores: [
'Owners'
],
...
app/view/Owners.js
Ext.define('Mb.view.winbiz.Owners', {
extend: 'Ext.grid.Panel',
alias: 'widget.test-gridPanel',
store: 'winbiz.Owners',
columns: [{
...
视图在控制器中实例化:
Ext.define('Mb.controller.Winbiz', {
extend: 'Ext.app.Controller',
views: [
'Owners'
],
init: function(){
this.control({
'menu #test': {click: this.onMenuTest},
})
},
onMenuTest: function(){
this.getController('Main').addToMainTab('test-gridPanel');
},
【问题讨论】:
标签: extjs extjs4 extjs4.2 extjs-stores