Tengo un panel de formulario que usa un diseño de tabla para mostrar un formulario. Necesito agregar funcionalidad para agregar/eliminar un conjunto de componentes.Extjs no puede agregar/eliminar campos dinámicamente en el panel de formularios
El botón Agregar debe agregar una nueva fila de componentes debajo de los elementos existentes & El botón Eliminar debe eliminar la última fila agregada.
El panel de formas puede agregar un nuevo campo pero aparece debajo de los botones y el formulario no aumenta de ancho (consulte la captura de pantalla a continuación). Intenté esto con las funciones insertar y agregar, pero ambas tienen el mismo efecto.
¿Alguien sabe cómo: 1) Puedo agregar una serie de componentes en la próxima fila? 2) Cómo puedo eliminar la siguiente fila.
código FormPanel parcial código del botón &:
![SearchForm = Ext.extend(Ext.FormPanel, {
id: 'myForm'
,title: 'Search Form'
,frame:true
,waitMessage: 'Please wait.'
//,labelWidth:80
,initComponent: function() {
var config = {
items: [{
layout:{
type:'table',
columns:5
},
buttonAlign:'center',
defaults:{
//width:150,
//bodyStyle:'padding:100px'
style:'margin-left:20px;'
},
items:[//row 1
{
xtype: 'label',
name: 'dateLabel',
cls: 'f',
text: "Required:"
},
{
xtype: 'container',
layout: 'form',
items: {
xtype: 'datefield',
fieldLabel: "From Date",
value: yesterday,
width: 110,
id: 'date1'
}
}][1]
buttons: [{
text: 'Add More Criteria (max 10 items)',
id: "addBtn",
scope: this,
handler: function(){
alert('hi');
/*this.items.add({
xtype : 'textfield',
fieldLabel : 'Extra Field',
name : 'yourName',
id : 'yourName'
}); */
this.insert(4,{
xtype: 'textfield',
id: 'input20',
//hideLabel: true,
width: 180,
fieldLabel: 'hi'
});
this.doLayout();
}
}
También he visto algo que tiene un fieldContainer contenido dentro de un fieldSet, ¿sería esta la forma correcta de hacerlo o simplemente sería suficiente agregar otro fieldset como fila? – pm13
simplemente agregando otro fieldset como una fila debería ser suficiente –