dataTransfer.setData() 用法詳解

admin發表於2018-08-28

此方法用來新增一個指定型別的拖拽資料項。

如果給定型別的資料不存在,則將其新增到拖動資料儲存末尾,那麼types列表中的最後一個項是新型別。如果給定型別的資料已經存在,現有資料將被替換,但是資料項在資料項列表中的位置不變。

語法結構:

[JavaScript] 純文字檢視 複製程式碼
dataTransfer.setData(format, data);

引數解析:

(1).format:DOMString型別資料,JavaScript中,DOMString可以理解為string型別;規定資料項的資料型別。

(2).data:DOMString型別資料,規定要新增到資料項的資料。

瀏覽器支援:

(1).IE10+瀏覽器支援此屬性。

(2).edge瀏覽器支援此屬性。

(3).谷歌瀏覽器支援此屬性。

(4).opera瀏覽器支援此屬性。

(5).火狐瀏覽器支援此屬性。

(6).safria瀏覽器支援此屬性。

程式碼例項:

[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 dragStart(ev){
  ev.dataTransfer.setData("Text",ev.target.id);
}
 
function dragOver(ev){
  ev.preventDefault();
}
 
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");
 
  img.ondragstart=dragStart;
  odiv.ondragover=dragOver;
  odiv.ondrop=drop;
}
</script>
</head>
<body>
<div id="ant"></div>
<br/>
<img id="img" src="template/comiis_jdls/img/JS.png" draggable="true"/>
</body>
</html>

在資料項列表中新增一個"Text"型別資料,值為被拖動元素的id屬性值。