Sencha:在其他视图中使用商店

时间:2013-08-14 07:45:16

标签: extjs sencha-touch datastore

我有一个商店,在登录成功时在控制器中创建。代码如下所示:

controller是login.js

    //////////// create a JSONstore and load companies into it ////////////// 
var companies_data = new Ext.data.JsonReader({}, [ 'companyame']);      
    var storeCompanies = new Ext.data.JsonStore({
    storeId: 'storeCompanies', 
          proxy: new Ext.data.HttpProxy({
              type: 'GET',
            url: url+'dashboard/?Uid='+uid+'&Ude='+ude,
            reader: {
                type: 'json',
                root: 'root',
                totalProperty: 'total'
            },
            headers: {
               'Accept' : 'application/json;application/x-www-form-urlencoded',
               'Content-Type' : 'application/x-www-form-urlencoded',
            },
             params: {
                Uid: localStorage.uid,
                Ude: localStorage.ude,
            },
          }),
          reader: companies_data,  
          root: 'd',
          type: 'localstorage',
          autoLoad : true,
          id: 'company_Id',
          scope : this,
          fields: ['companyname']
        });

代码是一个函数,在成功登录时调用,并将值传递给它。

这样可以正常工作,并且商店可用于登录视图

我需要将商店提供给我的主视图。

在我的login.js控制器中,我已经提到了这样的主视图:

Ext.define('axis3.controller.Login', {
extend: 'Ext.app.Controller',
config: {
    refs: {
        loginView: loginview,
        mainView: 'mainview',
        chartView: 'chartview'
    },
    control: {
        loginView: {
            signInCommand: 'onSignInCommand'
        },
        mainMenuView: {
            onSignOffCommand: 'onSignOffCommand'
        }
    }
},

但这似乎没有帮助。

当我在主视图中使用以下内容时

var companyStore = Ext.getStore('storeCompanies'); // 
console.log('1-Number : ' + companyStore.getCount()); // Using getCount method.
var anotherCompany = { companyname: 'North Wells'};
companyStore.add(anotherCompany);  // 
console.log('2-Number : ' + companyStore.getCount()); // Using getCount method.
//////////////

Ext.define('axis3.view.Main', {
extend: 'Ext.form.Panel',
requires: ['Ext.TitleBar','Ext.data.Store'],
alias: 'widget.mainview',......................

我收到此错误:

  

TypeError:'undefined'不是对象(评估   'companyStore.getCount')

如何在不同的视图中使用我的商店?

2 个答案:

答案 0 :(得分:0)

storeId,试试这个

var storeCompanies = Ext.create("Ext.data.JsonStore",{
          storeId: 'storeCompanies', // add this line
          proxy: new Ext.data.HttpProxy({
            type: 'GET',
            url: url+'dashboard/?Uid='+uid+'&Ude='+ude,
            reader: {
                type: 'json',
                root: 'root',
                totalProperty: 'total'
            },
            headers: {
               'Accept' : 'application/json;application/x-www-form-urlencoded',
               'Content-Type' : 'application/x-www-form-urlencoded',
            },
             params: {
                Uid: localStorage.uid,
                Ude: localStorage.ude,
            },
          }),
          reader: companies_data,  
          root: 'd',
          type: 'localstorage',
          autoLoad : true,
          id: 'company_Id',
          scope : this,
          fields: ['companyname']
        });

现在使用Ext.getStore('storeCompanies');

再试一次

答案 1 :(得分:0)

如果已经弄清楚了问题。该视图尝试在存储之前使用该存储。只有在用户登录时才会创建商店。

我决定使用的解决方案是创建一个空商店,然后在成功登录时向其添加数据。

var anotherCompany = {companyname: 'Keep Groom'};
companiesStore2.add(anotherCompany);  // Use the add function to add records or model instances.

这似乎有效