Próbuję utworzyć kilka elementów, które można przeciągnąć (tokeny), które można przeciągnąć wewnątrz elementu dającego się dostosować. Wygląda na to, że wszystko działa, oprócz tego ... po przeciągnięciu jednego elementu i upuszczeniu go, nie mogę go ponownie przeciągnąć. Wygląda na to, że nie mogę ponownie powiązać z tym wydarzeniem dragstart.Elementy przeciągalne HTML5 w obrębie contenteditable div - przestaje działać po pierwszym dropie - dlaczego?
Każdy pomysł, dlaczego tak się dzieje i jak mogę to naprawić?
Oto link do mojego skrzypce: http://jsfiddle.net/gXScu/1/
HTML:
<div id="editor" contenteditable="true">
Testime siinkohal seda, et kuidas<br />
on võimalik asja testida.
<span class="draggable" draggable="true" contenteditable="false">Token</span>
</div>
<span class="draggable" draggable="true" contenteditable="false">Token 2</span>
JavaScript (jQuery)
var bindDraggables = function() {
console.log('binding draggables', $('.draggable').length);
$('.draggable').off('dragstart').on('dragstart', function(e) {
if (!e.target.id)
e.target.id = (new Date()).getTime();
e.originalEvent.dataTransfer.setData('text/html', e.target.outerHTML);
console.log('started dragging');
$(e.target).addClass('dragged');
}).on('click', function() {
console.log('there was a click');
});
}
$('#editor').on('dragover', function (e) {
e.preventDefault();
return false;
});
$('#editor').on('drop', function(e) {
e.preventDefault();
var e = e.originalEvent;
var content = e.dataTransfer.getData('text/html');
var range = null;
if (document.caretRangeFromPoint) { // Chrome
range = document.caretRangeFromPoint(e.clientX, e.clientY);
}
else if (e.rangeParent) { // Firefox
range = document.createRange();
range.setStart(e.rangeParent, e.rangeOffset);
}
console.log('range', range)
var sel = window.getSelection();
sel.removeAllRanges(); sel.addRange(range);
$('#editor').get(0).focus(); // essential
document.execCommand('insertHTML',false, content);
//$('#editor').append(content);
sel.removeAllRanges();
bindDraggables();
console.log($('[dragged="dragged"]').length);
$('.dragged').remove();
});
bindDraggables();
CSS:
#editor {
border: 2px solid red;
padding: 5px;
}
.draggable {
display: inline-block;
padding: 3px;
background: yellow;
cursor: move !important;
}
Działa doskonale w Firefoksie, dlatego najprawdopodobniej jest to błąd przeglądarki Chrome. I występuje tylko wtedy, gdy używasz komendy 'insertHTML'. Kiedy zastąpiłem go '$ ('# editor') append (content)' wszystko działa dobrze ... – Reinmar