HTML5 拖拽教程前言

admin發表於2019-02-13

HTML5之前,元素拖拽效果通常要利用mousedown、mouseove和mouseup等事件持續監聽滑鼠動作。

以此來持續獲取滑鼠的座標來修改元素的座標,但是此種方式效能差程式碼量大。

上述類似程式碼可以參閱JavaScript 限定範圍拖動效果一章節。

HTML5新增Drag &Drop事件,實現拖動效果更佳方便,效能也更好。

程式碼例項如下:

[HTML] 純文字檢視 複製程式碼執行程式碼
<!DOCTYPE html>
<html lang="zh-cn">
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css">
#ant {
  width:198px; 
  height:66px;
  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));
}
window.onload=function(){
  let odiv=document.getElementById("ant");
  let img=document.getElementById("img");
  odiv.ondrop=drop;
  odiv.ondragover=allowDrop;
 
  img.ondragstart=drag;
}
</script>
</head>
<body>
<div id="ant"></div>
<br/>
<img id="img" src="template/sentce/src/images/logo.png" draggable="true"/>
</body>
</html>

程式碼簡單演示利用HTML5新增特性實現的拖拽效果,後續文章會對實現原理進行詳細介紹。

相關文章