HTML5 拖放(Drag 和 Drop)

拖放

拖放是一种常见的特性,即抓取对象以后拖到另一个位置。

在 HTML5 中,拖放是标准的一部分,任何元素都能够拖放。

设置元素为可拖放

首先,为了使元素可拖动,把 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));
}

HTML5 拖放实例

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

实例

<!DOCTYPE HTML>
<html>
<head>
<style type="text/css">
#div1,
#div2{
float:left;
width:200px;
height:50px;
margin:10px;
padding:10px;
border:1px solid #aaaaaa;
}
</style>
<script type="text/javascript">
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>小兔子回家</div>
<div id="div1" ondrop="drop(event)" ondragover="allowDrop(event)"></div> <div style="margin-top: 120px">小猪猪回家</div>
<div id="div2" ondrop="drop(event)" ondragover="allowDrop(event)"></div>
<div>
<img id="drag1" src="https://images.cnblogs.com/cnblogs_com/1101-/1676411/t_200321084900%E5%85%94.png?a=1584942477084" draggable="true" ondragstart="drag(event)" width="50" height="50" />
<img id="drag2" src="https://images.cnblogs.com/cnblogs_com/1101-/1676411/t_2003231135343.png" draggable="true" ondragstart="drag(event)" width="40" height="40" />
<img id="drag3" src="https://images.cnblogs.com/cnblogs_com/1101-/1676411/t_200321084900%E5%85%94.png?a=1584942477084" draggable="true" ondragstart="drag(event)" width="50" height="50" />
</div>
</body>
</html>

代码解释:

  • 调用 preventDefault() 来避免浏览器对数据的默认处理(drop 事件的默认行为是以链接形式打开)

  • 通过 dataTransfer.getData("Text") 方法获得被拖的数据。该方法将返回在 setData() 方法中设置为相同类型的任何数据。

  • 被拖数据是被拖元素的 id ("drag1")

  • 把被拖元素追加到放置元素(目标元素)中

最新文章

  1. DI中Transient Scoped Singleton Instance的区别
  2. jquery cookie的用法
  3. 【重要!】告K2老客户书
  4. 你能熟练使用Dictionary字典和List列表吗?(转)
  5. git本地文件回滚操作
  6. MFC单文档程序结构
  7. yii2的变量是如何注入到视图中去的?
  8. Ecplise 中 加载JDBC 连接 Mysql 数据库读取数据
  9. spring boot + easypoi两行代码excel导入导出
  10. LeetCode算法题-Range Sum Query Immutable(Java实现)
  11. Linux 小知识翻译 - 「BitTorrent」
  12. layui(九)——flow组件常见用法总结
  13. lamda表达式和stream
  14. 入坑docker
  15. Appium移动自动化测试入门及简单实例(python)
  16. jQuery学习笔记(Ajax)
  17. 2018.08.16 洛谷P2029 跳舞(线性dp)
  18. Memcachedclient-XMemcached使用
  19. 【OCP题库-12c】最新CUUG OCP 071考试题库(71题)
  20. ECharts模块化使用5分钟上手

热门文章

  1. java实现坐标
  2. Java实现花朵数
  3. 关于晶体问题TCXO_14.7456MHZ
  4. 两种方法设置MMDVM静态组
  5. android在service中stopself遇到的问题
  6. Postsharp简单试用——在业务逻辑类上添加日志记录
  7. dbca oracle 12 c 遇到ora27125
  8. HttpClient 常用方法封装
  9. 8种排序算法 Java实现
  10. Linux MySQL集群搭建之主从复制