Tengo:ExtJS - Formulario enviar código
win = desktop.createWindow({
id: 'admin-win',
title: 'Add administration users',
width: 740,
height: 480,
iconCls: 'icon-grid',
animCollapse: false,
constrainHeader: true,
xtype: 'form',
bodyPadding: 15,
url: 'save-form.php',
items: [{
xtype: 'textfield',
fieldLabel: 'Field',
name: 'theField'
}],
buttons: [{
text: 'Submit',
handler: function() {
var form = this.up('form').getForm();
if (form.isValid()) {
form.submit({
success: function (form, action) {
Ext.Msg.alert('Success', action.result.message);
},
failure: function (form, action) {
Ext.Msg.alert('Failed', action.result ? action.result.message : 'No response');
}
});
}
}
}]
});
y los botones no funcionan. Crea un error: this.up ('form') no está definido. ¿Cómo puedo llamar a getForm() en un código como ese?
ACTUALIZACIÓN: ¡Gracias por la respuesta realmente rápida! he modificado el código para mis necesidades, eso es todo, y funciona con el escritorio Ejemplo:
win = desktop.createWindow({
id: 'admin-win',
title: 'Add administration users',
width: 740,
iconCls: 'icon-grid',
animCollapse: false,
constrainHeader: true,
items: [{
xtype: 'form',
bodyPadding: 15,
url: 'save-form.php',
items: [{
xtype: 'textfield',
fieldLabel: 'Field',
name: 'theField'
}],
buttons: [{
text: 'Submit',
handler: function() {
var form = this.up('form').getForm();
if (form.isValid()) {
this.up().up().submit({
success: function (form, action) {
Ext.Msg.alert('Success', action.result.message);
},
failure: function (form, action) {
Ext.Msg.alert('Failed', action.result ? action.result.message : 'No response');
}
});
}
}
}]
}]
});
¿Es esta su código completo? ¿Qué desktop.createWindow hace? Pregunto esto porque parece que estás tratando de crear una ventana pero usando las opciones de Ext.form.Panel. – davidbuzatto
Está basado en el Ejemplo de Escritorio ExtJS. Quiero crear una ventana solo con formulario. –
¿Así que copia/pega este código? – davidbuzatto