嗨,我是Sencha touch的新手,我遇到了问题。我查了一下我能找到的关于我的问题的答案并尝试了所有这些但是我错过了一些东西。
我想在我的视图中添加一个包含一些文本字段和列表的面板。但我的列表总是在后台,我不能再点击它了。
图像:
以下是代码:
Ext.define("NotesApp.view.TestPanel", {
extend: "Ext.Panel",
alias: "widget.testpanel",
config: {
listeners: [{
delegate: '#logOutButton',
event: 'tap',
fn: 'onLogOutButtonTap'
}],
layout: {
type: 'fit',
fullscreen: true
}
},
initialize: function () {
this.callParent(arguments);
var logOutButton = {
xtype: "button",
text: 'Log Out',
ui: 'action',
}
var form = Ext.create
(
'Ext.form.Panel',
{
config:
{
layout: 'fit',
height: '300px',
},
items:
[
{
xtype: 'textfield',
name: 'name',
label: 'Name'
},
{
xtype: 'emailfield',
name: 'email',
label: 'Email'
},
{
xtype: 'passwordfield',
name: 'password',
label: 'Password'
},
]
}
);
var newButton = {
xtype: "button",
text: 'New',
ui: 'action',
handler: this.onNewButtonTap,
scope: this
};
var notesList = {
xtype: "noteslist",
layout: 'fit',
store: Ext.getStore("Notes"),
listeners: {
disclose: { fn: this.onNotesListDisclose, scope: this }
}
};
var topToolbar = {
xtype: "toolbar",
title: 'My Notes',
docked: "top",
items: [logOutButton, {xtype: 'spacer'}, newButton]
};
var bottomToolbar =
{
xtype: "toolbar",
docked: "bottom",
layout:
{
type: 'hbox',
pack: 'center'
},
items:
[
{
xtype: "button",
text: "testButton",
width: "100"
}
]
}
this.add([topToolbar,notesList, form, bottomToolbar]);
},
onNewButtonTap: function() {
this.fireEvent("newNoteCommand", this);
},
onNotesListDisclose: function (list, record, target, index, evt, options) {
console.log("editNoteCommand");
this.fireEvent('editNoteCommand', this, record);
},
onLogOutButtonTap: function () {
this.fireEvent('signOutCommand')
}
});
控制器:
Ext.define("NotesApp.controller.Notes", {
extend: "Ext.app.Controller",
config: {
refs: {
notesListContainer: "noteslistcontainer",
noteEditor: {
selector: 'noteeditor',
xtype: 'noteeditor',
autoCreate: true
},
},
control: {
notesListContainer: {
newNoteCommand: "onNewNoteCommand",
editNoteCommand: "onEditNoteCommand"
},
noteEditor: {
saveNoteCommand: "onSaveNoteCommand",
deleteNoteCommand: "onDeleteNoteCommand",
backToHomeCommand: "onBackToHomeCommand"
}
}
},
slideLeftTransition: { type: 'slide', direction: 'left' },
slideRightTransition: { type: 'slide', direction: 'right' },
getRandomInt: function (min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
},
activateNoteEditor: function (record) {
var noteEditor = this.getNoteEditor();
noteEditor.setRecord(record); // load() is deprecated.
Ext.Viewport.animateActiveItem(noteEditor, this.slideLeftTransition);
},
activateNotesList: function () {
Ext.Viewport.animateActiveItem(this.getNotesListContainer(), this.slideRightTransition);
},
onNewNoteCommand: function() {
var now = new Date();
var noteId = (now.getTime()).toString() + (this.getRandomInt(0, 100)).toString();
var newNote = Ext.create("NotesApp.model.Note",
{
id: noteId,
dateCreated: now,
title: "",
narrative: ""
});
this.activateNoteEditor(newNote);
},
onEditNoteCommand: function(list, record) {
this.activateNoteEditor(record);
},
onDeleteNoteCommand: function() {
var noteEditor = this.getNoteEditor();
var currentNote = noteEditor.getRecord();
var notesStore = Ext.getStore("Notes");
notesStore.remove(currentNote);
notesStore.sync();
this.activateNotesList();
},
onBackToHomeCommand: function() {
this.activateNotesList();
},
onSaveNoteCommand: function() {
var noteEditor = this.getNoteEditor();
var currentNote = noteEditor.getRecord();
var newValues = noteEditor.getValues();
currentNote.set("title", newValues.title);
currentNote.set("narrative", newValues.narrative);
var errors = currentNote.validate();
if (!errors.isValid()) {
Ext.Msg.alert('Wait!', errors.getByField("title")[0].getMessage(), Ext.emptyFn);
currentNote.reject();
return;
}
var notesStore = Ext.getStore("Notes");
if (null == notesStore.findRecord('id', currentNote.data.id)) {
notesStore.add(currentNote);
}
notesStore.sync();
notesStore.sort([{ property: 'dateCreated', direction: 'DESC'}]);
this.activateNotesList();
},
launch: function() {
this.callParent(arguments);
Ext.getStore("Notes").load();
},
init: function() {
this.callParent(arguments);
}
});
列表:
Ext.define("NotesApp.view.NotesList", {
extend: "Ext.dataview.List",
alias: "widget.noteslist",
config:
{
loadingText: "Loading Notes...",
emptyText: "<div class=\"notes-list-empty-text\">No notes found.</div>",
onItemDisclosure: true,
grouped: true,
itemTpl: "<div class=\"list-item-title\">{title}</div><div class=\"list-item-narrative\">{narrative}</div>",
},
});
答案 0 :(得分:0)
很难告诉你如何在没有控制器存在的情况下解决问题,因为我无法模拟上述问题。但这是基于我测试的提供的代码我的预感,问题可能源于滥用面板。由于面板是所有浮动和模态的基础,在这种情况下这不是你想要的(这是Sencha在行动中触及的状态pg76)。 noteslist也有布局适合但你没有说明高度。拟合采用其父级的高度,但我们不知道在使用add时父级高度是多少。最后,我建议你从初始化函数中取出所有内容并将其放入配置项目中,如下所示(现在记住最后一个是建议)祝你好运:)
config : {
listeners : [ {
delegate : '#logOutButton',
event : 'tap',
fn : 'onLogOutButtonTap'
} ],
items : [ {
xtype : "toolbar",
title : 'My Notes',
docked : "top",
items : [ {
xtype : "button",
text : 'Log Out',
ui : 'action',
}, {
xtype : 'spacer'
}, {
xtype : "button",
text : 'New',
ui : 'action',
handler : this.onNewButtonTap,
scope : this
} ]
}, {
xtype : 'textfield',
name : 'name',
label : 'Name'
}, {
xtype : 'emailfield',
name : 'email',
label : 'Email'
}, {
xtype : 'passwordfield',
name : 'password',
label : 'Password'
}, {
xtype : "toolbar",
docked : "bottom",
layout : {
type : 'hbox',
pack : 'center'
},
items : [ {
xtype : "button",
text : "testButton",
width : "100"
} ]
}, {
// xtype : "noteslist",
layout : 'vbox',
store : Ext.getStore("Notes"),
listeners : {
disclose : {
fn : this.onNotesListDisclose,
scope : this
}
}
} ]
}
仅供参考我刚刚从初始化中删除了所有内容 this.callParent(参数); 但我不认为你需要它,因为这将调用其父构造函数