2

我有一个ProjectsController赞:

Ext.define('SimpleTodo.controller.ProjectsController', {
    extend: 'Ext.app.Controller',
    refs: [
        { ref: 'addProjectPanel', selector: '#addProjectPanel' }
    ],
    init: function() {
        this.control({
            'button[action=addProject]': {
                click: this.addProject
            }
        });
    },
    addProject: function() {
        var form = this.getAddProjectPanel().getForm();
        if (form.isValid()) {
            var projectsStore = Ext.data.StoreManager.lookup('projects'); // Am getting null here
            projectsStore.add(form.getFieldValues());
            projectsStore.sync();
        } else {
            Ext.Msg.alert('INVALID!');
        }
    }
});

我相信问题是因为商店还没有初始化?那我应该如何修改我的代码?我的商店定义如下:

Ext.define('SimpleTodo.store.Projects', {
    extend: 'Ext.data.Store',
    requires: [
        'SimpleTodo.model.Project'
    ],
    model: 'SimpleTodo.model.Project',
    storeId: 'projects'    
});

我在尝试加载我的商店时遇到了同样的问题,从而填充了我的 Gridview/Table。我通过将功能移动到启动来修复它,不知道这是不是正确的方法?在文档中,init使用

Ext.define('SimpleTodo.controller.SidebarController', {
    extend: 'Ext.app.Controller',
    ...
    launch: function() {
        var projectsStore = Ext.data.StoreManager.lookup('projects');
        projectsStore.load();
    },
4

2 回答 2

1

添加

stores:
[
  'Projects'
],

到控制器代码,然后你可以使用

getProjectsStore();

参考。看看http://docs.sencha.com/ext-js/4-0/#!/guide/mvc_pt3, 1. 获取参考

于 2012-05-25T09:42:08.023 回答
0

您是否配置了代理来加载数据?

无论如何放置模型:[模型名称],商店:[商店名称],

进入控制器

设置成 Store autoLoad:true;

在模型中设置一个代理来告诉如何将数据加载到存储中。

参考: http ://docs.sencha.com/ext-js/4-1/#!/api/Ext.data.proxy.Proxy

于 2012-05-22T12:17:39.920 回答