HTML5拖放

在HTML5中,拖放(Drag和Drop)是一项非常常见的特性。它允许用户抓取某个元素并将其移动到不同的位置。实际上,HTML5标准中的所有元素都是可拖放的,用户可以使用此功能来构建交互式应用程序和网站。

一、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="img_logo.gif" draggable="true" ondragstart="drag(event)" width="336" height="69">

</body>
</html>

二、设置为可拖放

为了把一个元素设置为可拖放,请把 draggable 属性设置为 true:

<img draggable="true">

三、拖放内容

需要规定当元素被拖动时发生的事情。本文上述例子中,ondragstart 属性调用了一个 drag(event) 函数,规定拖动什么数据。

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

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

注意:数据类型是 "text",而值是这个可拖动元素的 id ("drag1")。

四、拖到何处

ondragover 事件规定被拖动的数据能够被放置到何处。默认地,数据/元素无法被放置到其他元素中。为了实现拖放,我们必须阻止元素的这种默认的处理方式。

这个任务由 ondragover 事件的 event.preventDefault() 方法完成:

event.preventDefault()

五、放置

当放开被拖数据时,会发生 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() 方法获得被拖的数据。该方法将返回在 setData() 方法中设置为相同类型的任何数据;
  • 被拖数据是被拖元素的 id ("drag1");
  • 把被拖元素追加到放置元素中。

六、浏览器支持

下列表格中的数字指示了完全支持拖放的首个浏览器版本。

浏览器 Google IE Firefox Safari Opera
版本 4 9 3.5 6 12
广告合作
QQ群号:707632017

温馨提示:

1、本网站发布的内容(图片、视频和文字)以原创、转载和分享网络内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。邮箱:2942802716#qq.com。(#改为@)

2、本站原创内容未经允许不得转裁,转载请注明出处“站长百科”和原文地址。

目录