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

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

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

簡介

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

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

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

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

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

定義和用法

在拖放的過程中會觸發(fā)以下事件:

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

瀏覽器支持

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

注意:Safari 5.1.2不支持拖動;在拖動元素時,每隔 350 毫秒會觸發(fā) 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)詳解與實例代碼

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

設(shè)置元素可拖放

首先,為了使元素可拖動,把 draggable 屬性設(shè)置為 true :

<img draggable="true">

拖動什么 - ondragstart 和 setData()

然后,規(guī)定當元素被拖動時,會發(fā)生什么。

在上面的例子中,ondragstart 屬性調(diào)用了一個函數(shù),drag(event),它規(guī)定了被拖動的數(shù)據(jù)。

dataTransfer.setData() 方法設(shè)置被拖數(shù)據(jù)的數(shù)據(jù)類型和值:

function drag(ev)
{
    ev.dataTransfer.setData("Text",ev.target.id);
}

在這個例子中,數(shù)據(jù)類型是 "Text",值是可拖動元素的 id ("drag1")。

放到何處 - ondragover

ondragover 事件規(guī)定在何處放置被拖動的數(shù)據(jù)。

默認地,無法將數(shù)據(jù)/元素放置到其他元素中。如果需要設(shè)置允許放置,我們必須阻止對元素的默認處理方式。

這要通過調(diào)用 ondragover 事件的 event.preventDefault() 方法:

event.preventDefault()

進行放置 - ondrop

當放置被拖數(shù)據(jù)時,會發(fā)生 drop 事件。

在上面的例子中,ondrop 屬性調(diào)用了一個函數(shù),drop(event):

function drop(ev)
{
    ev.preventDefault();
    var data=ev.dataTransfer.getData("Text");
    ev.target.appendChild(document.getElementById(data));
}

代碼解釋:

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

實現(xiàn)的結(jié)果如圖:

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

dataTransfer對象

在拖曳操作的過程中,我們可以用過dataTransfer對象來傳輸數(shù)據(jù),以便在拖曳操作結(jié)束的時候?qū)?shù)據(jù)進行其他的操作。

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

相關(guān)文檔推薦

這篇文章主要介紹了有關(guān)HTML5頁面在iPhoneX適配問題,需要的朋友可以參考下
本篇文章主要介紹了html5中canvas圖表實現(xiàn)柱狀圖的示例,本文使用canvas來實現(xiàn)一個圖表,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
Adobe公司出品的多媒體處理軟件產(chǎn)品線較多,涵蓋了音視頻編輯、圖像處理、平面設(shè)計、影視后期等領(lǐng)域。這篇文章主要介紹了Adobe Html5 Extension開發(fā)初體驗圖文教程,非常不錯,需要的朋
這篇文章主要介紹了基于HTML5的WebGL經(jīng)典3D虛擬機房漫游動畫,需要的朋友可以參考下
這篇文章主要介紹了html5實現(xiàn)移動端適配完美寫法,需要的朋友可以參考下
本篇文章主要介紹了HTML5響應(yīng)式(自適應(yīng))網(wǎng)頁設(shè)計的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
主站蜘蛛池模板: 久久久久国产精品夜夜夜夜夜 | 夜夜躁狠狠躁日日躁av | 丝袜美腿一区二区三区 | 中文字幕av一区二区三区谷原希美 | 欧美日韩国产在线观看 | 亚洲视频在线播放 | 亚洲黄色在线 | 欧美在线激情 | 国产主播精品 | 国产成人精品一区二区三区在线观看 | 日本国产精品 | 黄色片视频网站 | 日韩色av| 日狠狠| 精品久久一区 | 亚洲欧美视频 | 久久精品视频一区 | 国产精品美女 | 国产三级在线看 | 日本久久一区二区 | 国产小视频在线 | 日韩在线不卡视频 | 久久综合99| 欧美黄色一级大片 | 亚洲一区二区三区 | av片在线观看 | 欧美做受喷浆在线观看 | 欧美国产一区二区 | 丁香综合网 | 精品欧美一区二区精品久久 | 免费av一区 | 亚洲精品资源 | 国产极品国产极品 | 国精产品99永久一区一区 | 天天综合av | 国产成人高清 | 蜜桃精品噜噜噜成人av | 成年在线观看 | 国产探花视频在线观看 | 国产综合在线视频 | 久久艹精品 |