我正在创建 ListView 并使用我创建的商店中的一些数据填充它。
当我使用时将商店分配到列表视图
store : Ext.getStore('Feeds')
,我收到错误:
未捕获的TypeError:undefined不是函数
查看课程
Ext.define('Volt.view.FeedView', {
extend: 'Ext.Panel',
requires: [
'Ext.TitleBar',
'Ext.Button',
'Ext.Toolbar'
//'Ext.Panel'
],
xtype: 'feedViewCard',
config: {
iconCls: 'action',
title: 'FeedView',
layout: {
type: 'vbox'
},
items: [
{
xtype: 'feedlistview', // this is defined as a class that inherits from xtype = list
store: Ext.getStore('Feeds'), //removing this line gives no error
flex: 1,
}
}
}
]
},
});
商店类
Ext.define("Volt.store.Feeds", {
extend: "Ext.data.Store",
requires: "Ext.data.proxy.LocalStorage",
config: {
model: "Volt.model.Feed",
data: [
{ title: "Feed 1", narrative: "narrative 1" },
{ title: "Note 2", narrative: "narrative 2" },
{ title: "Note 3", narrative: "narrative 3" },
{ title: "Note 4", narrative: "narrative 4" },
{ title: "Note 5", narrative: "narrative 5" },
{ title: "Note 6", narrative: "narrative 6" }
],
sorters:[
{
property: 'dateCreated',
direction: 'DESC'
}
]
}
});
模型类
Ext.define("Volt.model.Feed", {
extend: "Ext.data.Model",
config: {
idProperty: 'id',
fields: [
{ name: 'id', type: 'int' },
{ name: 'dateCreated', type: 'date', dateFormat: 'c' },
{ name: 'title', type: 'string' },
{ name: 'narrative', type: 'string' }
],
validations: [
{ type: 'presence', field: 'id'},
{ type: 'presence', field: 'dateCreated'},
{ type: 'presence', field: 'title', 'message': 'Enter a valid title'}
]
}
});
答案 0 :(得分:1)
您正试图在定义时间内获取商店,但该商店尚不存在。如果Feeds
商店列在应用程序的stores:[]
或控制器中,则只需将其设置为文本store:'Feeds'
。
当app初始化时,它检测到store是一个字符串并为你调用Ext.getStore。
您可能也对Ext Component Life Cycle和/或Ext Application Startup Sequence
感兴趣