久久久久久久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久久精品一区二区永久免费 | 欧美黄色一区 | 日韩av一区二区在线观看 | 国产男女精品 | 四虎影视免费观看 | 日韩成人久久 | 欧美精品一区在线发布 | 亚洲成av人片在线观看 | 亚洲精品国产精品国自产在线 | 日韩1区2区 | 久久久久久久久久久国产 | 成人福利在线观看 | 五月天婷婷丁香 | 欧美激情欧美激情在线五月 | 日日爱夜夜操 | 日韩精品久久一区二区三区 | 欧美国产日韩一区二区三区 | 久久天天躁狠狠躁夜夜躁2014 | 91精品久久久久久久久中文字幕 | 欧美vide | 久久久精 | 久久影音先锋 | 欧美综合一区二区三区 | 成人在线中文字幕 | 免费午夜视频在线观看 | 欧美日韩一区在线播放 | 日韩中文字幕视频在线观看 | 在线2区| 国产在线观看福利 | 欧美综合久久久 | 国产激情视频网站 | 精品香蕉一区二区三区 | 97色综合| 成人免费视频网站在线观看 | 国产在线精品一区二区 | 免费中文字幕 | 日韩在线观看 | 国产在线观看免费 | 激情六月丁香婷婷 | 午夜手机在线视频 | 日韩精品一区二区三区 |