Mam panel formularza, który używa układu tabeli do wyświetlania formularza. Muszę dodać funkcjonalność, aby dodać/usunąć zestaw komponentów.Extjs nie może dynamicznie dodawać/usuwać pól w formpanelu
Przycisk Dodaj powinien dodać nowy wiersz komponentów pod istniejącymi elementami. & Przycisk Usuń powinien usunąć ostatnio dodany wiersz.
Formpanel może dodać nowe pole, ale pojawia się pod przyciskami, a formularz nie zwiększa szerokości (zobacz zrzut ekranu poniżej). Próbowałem tego zarówno z funkcją wstawiania i dodawania, ale oba mają taki sam efekt.
Czy ktoś wie, jak: 1) Czy mogę dodać serię komponentów w następnym rzędzie? 2) Jak mogę usunąć następny wiersz.
Częściowa kod FormPanel kod & przycisk:
![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();
}
}
Widziałem również coś, co ma poleContainer przechowywane w zestawie pól, czy byłby to właściwy sposób, aby to osiągnąć, czy wystarczyłoby dodanie innego zestawu pól jako wystarczającego rzędu? – pm13
wystarczy dodać kolejny zestaw pól, ponieważ wiersz powinien być wystarczający –