久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

HTML5 拖放(Drag 和 Drop)詳解與實例代碼

本篇文章主要介紹了HTML5 拖放(Drag 和 Drop)詳解與實例代碼,具有一定的參考價值,有興趣的可以了解一下

簡介

拖放是一種常見的特性,即抓取對象以后拖到另一個位置。

在 HTML5 中,拖放是標準的一部分,任何元素都能夠拖放。

先點擊一個小例子:在用戶開始拖動 <p> 元素時執行 JavaScript

<p draggable="true" ondragstart="myFunction(event)">拖動我!</p>

提示: 鏈接和圖片默認是可拖動的,不需要 draggable 屬性。

定義和用法

在拖放的過程中會觸發以下事件:

  • 在拖動目標上觸發事件 (源元素):  ondragstart - 用戶開始拖動元素時觸發
    • ondrag - 元素正在拖動時觸發
    • ondragend - 用戶完成元素拖動后觸發
  • 釋放目標時觸發的事件:  ondragenter - 當被鼠標拖動的對象進入其容器范圍內時觸發此事件
    • ondragover - 當某被拖動的對象在另一對象容器范圍內拖動時觸發此事件
    • ondragleave - 當被鼠標拖動的對象離開其容器范圍內時觸發此事件
    • ondrop - 在一個拖動過程中,釋放鼠標鍵時觸發此事件

瀏覽器支持

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

注意:Safari 5.1.2不支持拖動;在拖動元素時,每隔 350 毫秒會觸發 ondragover 事件。

實例

先貼代碼,再逐一解釋:

<!DOCTYPE html>
<html>
<head>
<title>HTML5拖拽</title>
<meta charset="utf-8">
<style>
#div1 {width:350px;height:70px;padding:10px;border:1px solid #aaaaaa;}
</style>
</head>
<body>
<p>拖動img_w3slogo.gif圖片到矩形框中:</p>
<div id="div1" ondrop="drop(event)" ondragover="allowDrop(event)"></div>
<br>
<img id="drag1" src="images/img_w3slogo.gif" draggable="true" ondragstart="drag(event)" width="300" height="56">

<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>
</body>
</html>

拖拽前的頁面效果為:

 HTML5 拖放(Drag 和 Drop)詳解與實例代碼

下面分別來解析下上面代碼的意思。

設置元素可拖放

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

代碼解釋:

  • 調用 preventDefault() 來避免瀏覽器對數據的默認處理(drop 事件的默認行為是以鏈接形式打開)
  • 通過 dataTransfer.getData("Text") 方法獲得被拖的數據。該方法將返回在 setData() 方法中設置為相同類型的任何數據。
  • 被拖數據是被拖元素的 id ("drag1")
  • 把被拖元素追加到放置元素(目標元素)中

實現的結果如圖:

HTML5 拖放(Drag 和 Drop)詳解與實例代碼 

dataTransfer對象

在拖曳操作的過程中,我們可以用過dataTransfer對象來傳輸數據,以便在拖曳操作結束的時候對數據進行其他的操作。

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了有關HTML5頁面在iPhoneX適配問題,需要的朋友可以參考下
本篇文章主要介紹了html5中canvas圖表實現柱狀圖的示例,本文使用canvas來實現一個圖表,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
Adobe公司出品的多媒體處理軟件產品線較多,涵蓋了音視頻編輯、圖像處理、平面設計、影視后期等領域。這篇文章主要介紹了Adobe Html5 Extension開發初體驗圖文教程,非常不錯,需要的朋
這篇文章主要介紹了基于HTML5的WebGL經典3D虛擬機房漫游動畫,需要的朋友可以參考下
這篇文章主要介紹了html5實現移動端適配完美寫法,需要的朋友可以參考下
本篇文章主要介紹了HTML5響應式(自適應)網頁設計的實現,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
主站蜘蛛池模板: 99爱在线视频 | 国产一区二区三区四区三区四 | 亚洲国产成人久久综合一区,久久久国产99 | 国产电影一区二区在线观看 | 亚洲精品一区二三区不卡 | 特级一级黄色片 | 国产精品色哟哟网站 | 欧美亚州综合 | 精品一级毛片 | 国产亚洲精品久久久久动 | 国产成人精品视频在线观看 | 国产精品久久久久久久久久久久冷 | 精品欧美激情精品一区 | 国产精品免费大片 | 黄一区二区三区 | 久久久久久99| 欧美一区二区三区高清视频 | 精品国产乱码久久久久久a丨 | 亚洲精品大全 | 无吗视频 | 99国产在线| 日本电影免费完整观看 | 91亚洲国产亚洲国产 | 草久久| 91精品国产综合久久婷婷香蕉 | 国产免费视频在线 | 免费一级黄 | 亚洲精品中文在线观看 | 日韩视频在线免费观看 | 一区二区精品 | 国产精品99久久久精品免费观看 | 一级黄色生活视频 | 欧美日韩欧美 | 日韩欧美一区二区三区免费看 | 久久精品一级 | 欧美视频一区二区三区 | 日韩久久综合网 | 天天操天天插 | 夜夜操天天艹 | 国产一区二区三区在线 | 欧美精品福利 |