Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Drag drop with handle

Tags:

I have a div which contains a span that is 16x16px. I want the drag event to start when user clicks and drags this icon but it should drag the whole div. I'm trying to follow this tutorial here: http://www.html5rocks.com/en/tutorials/dnd/basics/

I cant figureout how to do this with a handle. Please adivise.

like image 752
Noitidart Avatar asked Oct 09 '14 16:10

Noitidart


1 Answers

Here's a working example: https://jsfiddle.net/pwt1cbjc/

var draggable = document.getElementById('draggable');
var handle = document.getElementById('handle');
var target = false;
draggable.onmousedown = function(e) {
    target = e.target;
};
draggable.ondragstart = function(e) {
    if (handle.contains(target)) {
        e.dataTransfer.setData('text/plain', 'handle');
    } else {
        e.preventDefault();
    }
};
#draggable {
    width: 100px;
    height: 100px;
    border: 1px solid black;
}
#handle {
    width: 0;
    height: 0;
    border-right: 20px solid transparent;
    border-top: 20px solid black;
    cursor: move;
}
<h1>Drag Handle</h1>

<div id="draggable" draggable="true">
    <div id="handle">
    </div>
</div>
like image 51
SaphuA Avatar answered Sep 18 '22 13:09

SaphuA