2012-05-16 11 views
11

Ho un set di elenchi trascinabili/ordinabili a cui aggiungo dinamicamente gli elementi, ma il problema è che una volta aggiunto un elemento, non è possibile spostarli alle nuove liste. Puoi vedere la funzionalità qui: http://jsfiddle.net/Y4T32/2/jQuery UI Draggable/Sortable - Elementi aggiunti dinamicamente non trascinabili

Trascinare un elemento dall'elenco disponibile a uno degli elenchi di destinazione, e vedrai che intendo. Ora aggiungi un "callout" e prova a trascinare il nuovo elemento su una delle colonne di destinazione.

Ho trovato un'altra risposta qui che funziona come voglio, ma non sono stato in grado di riprodurre i risultati ottenuti (e, naturalmente, non è possibile trovare la risposta ora). Qualche idea su ciò che sto facendo di sbagliato qui?

+0

ho trovato [questa risposta] (http://stackoverflow.com/questions/2583883/how-to-auto-apply-drag -and-drop-effect-to-dynamic-added-element) e ha apportato una leggera modifica. Tuttavia, mi sembra che questo potrebbe non essere il modo migliore per farlo. Ho aggiornato il mio violino. http://jsfiddle.net/Y4T32/7/ –

risposta

18

RISPOSTA AGGIORNATO

Bisogna chiamare .draggable() per ogni elemento che viene aggiunto. Il selettore jQuery che usi al momento dell'inizializzazione si applica solo agli elementi che esistono al momento, non a quelli che creerai.

Ecco alcuni JS che dovrebbe funzionare:

var draggable_opts = { 
      connectToSortable: ".sph-callout-portlet", 
      helper: "clone", 
      opacity: 0.75, 
      revert: 'invalid', 
      stop: function(event, ui) { 
       //alert(ui) 
      } 
     }; 

$(function() { 
    $(".sph-callout-portlet").sortable({ 
     opacity: 0.75, 
     placeholder: "ui-state-highlight", 
    }).disableSelection(); 

    $("#sph-callout-portlet-avail li").draggable(draggable_opts); 

    $(document).on("click",'#addNewCo',function(e){ 
     e.preventDefault(); 
     var newCo = $('<li>New Callout</li>').draggable(draggable_opts); 
     $('#sph-callout-portlet-avail').append(newCo); 
    }); 
});​ 

http://jsfiddle.net/SGevw/

+1

È una buona idea pubblicare il tuo codice qui nel caso in cui jsFiddle sia mai inaccessibile. Inoltre, una spiegazione di ciò che hai fatto è un vantaggio. – j08691

+1

@ j08691, fatto. Grazie per il testa a testa! – ubik

+0

@PedroFerreira, questo è MOLTO vicino a quello che voglio, eccetto che non voglio che gli utenti possano trascinarli tra le colonne o tornare alla colonna disponibile. Ecco perché ho dato loro nomi di classe diversi. –