视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
HTML5拖放效果的实现代码
2020-11-27 15:12:38 责编:小采
文档


拖放


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

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

Internet Explorer 9+, Firefox, Opera, Chrome, 和 Safari 支持拖动。

注意:Safari 5.1.2不支持拖动.

实例:

<!DOCTYPE html> 
<html> 
<head> 
 <title>拖放</title> 
 <style type="text/css"> 
 #p1{width:360px;height:220px;padding:20px;border:1px solid black;} 
 </style> 
 <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> 
 <p id="p1" ondrop="drop(event)" ondragover="allowDrop(event)"></p> 
 <br /> 
 <img id="drag1" src="img/bg_1.jpg" draggable="true" ondragstart="drag(event)" width="300px" height="180px" /> 
</body> 
</html>

首先,为了使元素可拖动,把draggable 属性设置为 true :<img draggable="true">

然后,规定当元素被拖动时,会发生什么。
在上面的例子中,ondragstart 属性调用了一个函数,drag(event),它规定了被拖动的数据。
dataTransfer.setData() 方法设置被拖数据的数据类型和值:

在这个例子中,数据类型是 "Text",值是可拖动元素的 id ("drag1")。

ondragover 事件规定在何处放置被拖动的数据。
默认地,无法将数据/元素放置到其他元素中。如果需要设置允许放置,我们必须阻止对元素的默认处理方式。
这要通过调用 ondragover 事件的 event.preventDefault() 方法:event.preventDefault()

当放置被拖数据时,会发生 drop 事件。
在上面的例子中,ondrop 属性调用了一个函数,drop(event):

代码解释:

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

来回拖动:

若要在两个地方来回拖动,只需将上面代码稍作修改就行了.
将body中的代码改成:

<body> 
 <p id="p1" ondrop="drop(event)" ondragover="allowDrop(event)"> 
 <img id="drag1" src="img/bg_1.jpg" draggable="true" ondragstart="drag(event)" width="300px" height="180px" /></p> 
 <p id="p2" ondrop="drop(event)" ondragover="allowDrop(event)"></p> 
</body>

然后在style样式中加上#p2就可以了:

<style type="text/css"> 
 #p1,#p2{width:360px;height:220px;padding:20px;border:1px solid black;} 
 </style>

这样就可以实现来回拖放了。

下载本文
显示全文
专题