2012-02-02 70 views
0

我与煎茶玩弄并创建了一个清单,商店和模型:煎茶触摸 - 扩展存储 - 构造函数调用

主:

Ext.Loader.setConfig({enabled: true}); 

Ext.application({ 
viewport: { 
    autoMaximize: false 
},                                         
name: 'Sencha',                                         

launch: function() {  
    Ext.create('Ext.List', { 
     fullscreen: true, 

     store: Ext.create('store.Test', { 
     }), 

     itemTpl: '{lastName}, {firstName} Age: {age}' 
    }); 
}                       
}); 

店:

Ext.define('store.Test', { 
extend: 'Ext.data.Store', 

model: 'model.User', 
data: [ 
    { firstName: 'Ed', lastName: 'Spencer', age: 30 }, 
    { firstName: 'Tommy', lastName: 'Maintz', age: 41 }, 
    { firstName: 'Aaron', lastName: 'Conran', age: 24 }, 
    { firstName: 'Jamie', lastName: 'Avins', age: 76 } 
] 
}); 

型号:

Ext.define('model.User', { 
extend: 'Ext.data.Model', 
fields: [ 
    { name: 'firstName', type: 'string' }, 
    { name: 'lastName', type: 'string' } 
] 
}); 

至此,一切正常。

然后,我创建了第二家店,其中有另一个领域'年龄'。我现在想要的是将一个参数“模型”传递给商店,以便能够在不同模型之间“切换”。 我想是这样的:

店:

Ext.define('store.Test', { 
extend: 'Ext.data.Store', 
myModel: null, 

constructor : function(model) { 
    myModel = model; 
}, 

model: this.myModel, 

data: [ 
    { firstName: 'Ed', lastName: 'Spencer', age: 30 }, 
    { firstName: 'Tommy', lastName: 'Maintz', age: 41 }, 
    { firstName: 'Aaron', lastName: 'Conran', age: 24 }, 
    { firstName: 'Jamie', lastName: 'Avins', age: 76 } 
] 
}); 

,并在主文件:

[...] 
     store: Ext.create('store.Test', { 
      model: 'model.UserWithAge' 
     }), 
[...] 

不过,谷歌给我:

Uncaught TypeError: Object [object Object],[object Object],[object Object],[object Object] has no method 'getRange' 

任何提示我做错了吗?

回答

0

没关系,然后我觉得这很容易。 而是与构造或者这样说,这是不够的,只是通过创建存储时,我媒体链接做了模型的东西搞乱:

主:

[...] 
    store: Ext.create('store.Test', { 
     model: 'model.UserWithAge' 
    }), 
[...] 

店:

Ext.define('store.Test', { 
extend: 'Ext.data.Store', 

model: 'model.User', //only set in case that model is not passed when created 

data: [ 
    { firstName: 'Ed', lastName: 'Spencer', age: 30 }, 
    { firstName: 'Tommy', lastName: 'Maintz', age: 41 }, 
    { firstName: 'Aaron', lastName: 'Conran', age: 24 }, 
    { firstName: 'Jamie', lastName: 'Avins', age: 76 } 
] 

} );