HTML5 拖放 (Drag / Drop)


uihtml

将图像拖动到右边矩形中.


拖放(Drag/drop)

拖放是一个非常常见的功能.当你"抓住"一个对象并将其拖到另一个位置.

在HTML5中,拖放是标准的一部分:任何元素都可以拖动.


浏览器支持

表中的数字指定了完全支持拖放的第一个浏览器版本.

API




Drag/Drop 4.0 9.0 3.5 6.0 12.0

HTML拖放示例

下面的示例是一个简单的拖放示例:

实例

<!DOCTYPE HTML>
<html>
<head>
<script>
function allowDrop(ev){
    ev.preventDefault();
}

function drag(ev){
   ev.dataTransfer.setData("text", ev.target.id);
}

function drop(ev){
    ev.preventDefault();
    var data = ev.dataTransfer.getData("text");
    ev.target.appendChild(document.getElementById(data));
}
</script>
</head>
<body>

<div id="div1" ondrop="drop(event)" ondragover="allowDrop(event)"></div>

<img id="drag1" src="/image/img_uihtml_logo.jpg" draggable="true"
ondragstart="drag(event)" width="336" height="69">

</body>
</html>
运行 »

它看上去也许有些复杂,不过我们可以分别研究拖放事件的每个部分.


设置元素可拖动

首先:要使元素可拖动,请将draggable属性设置为true:

<img draggable="true">

拖动什么(内容/元素) - ondragstart和setData()

然后,指定拖动元素时会发生的事情.

在上面的示例中, ondragstart属性调用一个函数drag(event),该函数指定要拖动的数据.

dataTransfer.setData()方法设置数据类型和拖动数据的值:

function drag(ev) {
    ev.dataTransfer.setData("text", ev.target.id);
}

在这种情况下,数据类型是"text",值是可拖动元素的id("drag1").


放到何处 - ondragover

ondragover事件规定被拖动的数据能够被放置到何处

默认情况下,数据/元素无法被放置到其他元素中.为了实现拖放,我们必须阻止元素的默认处理.

这是通过调用ondragover事件的event.preventDefault()方法完成的:

event.preventDefault()

进行放置 - ondrop

删除拖动的数据时,会发生drop事件.

在上面的例子中,ondrop属性调用一个函数drop(event):

function drop(ev){
    ev.preventDefault();
    var data = ev.dataTransfer.getData("text");
    ev.target.appendChild(document.getElementById(data));
}

代码解释:

  • 调用 preventDefault() 来避免浏览器对数据的默认处理(drop 事件的默认行为是以链接形式打开)
  • 通过 dataTransfer.getData("Text") 方法获得被拖的数据.该方法将返回在 setData() 方法中设置为相同类型的任何数据
  • 被拖数据是被拖元素的 id ("drag1")
  • 把被拖元素追加到放置元素(目标元素)中

更多例子

来回拖动图像

如何在两个<div>元素之间来回拖放图像:

运行 »