2015-02-14 8 views
5

Ho una tabella con quattro elenchi a discesa select2. Quando clonò la riga per duplicarla, gli elenchi a discesa della nuova riga sono disabilitati, non posso fare clic su di essi, cosa devo aggiungere nel mio codice per attivarli.Jquery - dropdown select2 disabilitato quando si clona una riga della tabella

La tabella HTML:

<table id="fla_inf" width="100%"> 
<tbody> 
<tr> 
<th class="tab_header" colspan="6">Flavors and Additives</th> 
</tr> 
<tr> 
<th class="tab_header_nam">Flavor Brand</th> 
<th class="tab_header_nam">Flavor Name</th> 
<th class="tab_header_nam">Dropper type</th> 
<th class="tab_header_nam">Quantity Unit</th> 
<th class="tab_header_nam">Quantity</th> 
<th class="tab_header_nam">Add/Remove row</th> 
</tr> 
<tr class="flavors"> 
<td>[brand_list]</td> 
<td><select id="arome0" class="select2-select"></select></td> 
<td><select id="dropper0" class="select2-select"> 
<option selected="selected" value="type1">type 1</option> 
<option value="type2">type 2-3</option> 
</select></td> 
<td><select id="qtyunit0" class="select2-select"> 
<option value="ml">ml</option> 
<option value="drops">drops</option> 
<option selected="selected" value="perc">%</option> 
</select></td> 
<td><input id="quantity0" class="quantity" type="number" /></td> 
<td><input class="addline" src="http://example.org/wp-content/uploads/2015/01/add.png" type="image" /><input class="remline" src="http://example.org/wp-content/uploads/2015/01/delete.png" type="image" /></td> 
</tr> 
</tbody> 
</table> 

e il codice jQuery:

// Add row to the table by cloning existing row 
$(document).on('click', '.addline', function(){ 

    var $tr = $(this).closest('tr'); 
    var allTrs = $tr.closest('table').find('tr'); 
    var lastTr = allTrs[allTrs.length-1]; 
    var $clone = $(lastTr).clone(); 
    $clone.find('td').each(function(){ 
     var el = $(this).find(':first-child'); 
     var id = el.attr('id') || null; 
     if(id) { 
      var i = id.substr(id.length-1); 
      var prefix = id.substr(0, (id.length-1)); 
      el.attr('id', prefix+(+i+1)); 
      el.attr('name', prefix+(+i+1)); 
     } 
    }); 
    $tr.closest('tbody').append($clone); 
}); 

risposta

8

cerco di evitare elementi di clonazione per questo tipo di ragione. Un'alternativa alla clonazione consiste nell'utilizzare un modello per l'html.

Se si desidera continuare la clonazione, è possibile annullare la strumentazione dei controlli Select2 nella riga originale prima di clonarla e riarruzzarli in seguito.

Si deseleziona i controlli Select2 con la funzione .select2('destroy').

$(document).on('click', '.addline', function() { 
    var $tr = $(this).closest('tr'); 
    var $lastTr = $tr.closest('table').find('tr:last'); 

    $lastTr.find('.select2-select').select2('destroy'); // Un-instrument original row 

    var $clone = $lastTr.clone(); // Clone row 

    $clone.find('td').each(function() { // Alter cloned ids 
     // ... 
    }); 

    $tr.closest('tbody').append($clone); // Append clone 

    $lastTr.find('.select2-select').select2(); // Re-instrument original row 

    $clone.find('.select2-select').select2(); // Instrument clone 
}); 

jsfiddle

+0

Grazie per sei risposta, io ti testarlo. Il motivo della clonazione è che ho bisogno del contenuto degli elenchi a discesa per evitare query inutili al database. Se distruggo la lista, perderà il suo contenuto? –

+0

@ user3515709 - "distruggi" semplicemente deselezionerà la selezione, non rimuoverà le opzioni. Lo puoi vedere nel jsfiddle. Capisco la tua ragione per la clonazione. –

+0

Grazie John, sta funzionando alla grande. –

Problemi correlati