欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解HTML5中的拖放事件(Drag 和 drop)

  發(fā)布時(shí)間:2016-11-14 16:12:22   作者:佚名   我要評論
大家都知道拖放是一種常見的特性,即抓取對象以后拖到另一個(gè)位置。在 HTML5 中,拖放是標(biāo)準(zhǔn)的一部分,任何元素都能夠拖放。拖放是在“拖放源(drag source)”和“拖放目標(biāo)(drop target)”之間傳輸數(shù)據(jù)的用戶界面。下面這篇文章給大家詳細(xì)介紹了HTML5中的拖放事件。

瀏覽器支持

Internet Explorer 9、Firefox、Opera 12、Chrome 以及 Safari 5 支持拖放。

注釋:在 Safari 5.1.2 中不支持拖放。

HTML5 拖放實(shí)例

<!DOCTYPE html>
<html> 
<head> 
<style type="text/css"> 
#div1 {width:488px;height:70px;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)); 
} 
</script> 
</head> 
<body> 
 
<p>請把 Aseoe logo的圖片拖放到矩形中:p> 
 
<div id="div1" ondrop="drop(event)" ondragover="allowDrop(event)">div> 
<br /> 
<img id="drag1" src="http://www.aseoe.com/statics/images/eoe/logo.png" 
draggable="true" ondragstart="drag(event)" /> 
 
</body> 
</html> 

設(shè)置元素為可拖放

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

拖動(dòng)什么 - ondragstart 和 setData()

然后,規(guī)定當(dāng)元素被拖動(dòng)時(shí),會(huì)發(fā)生什么。

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

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

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

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

放到何處 - ondragover

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

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

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

event.preventDefault()

進(jìn)行放置 - ondrop

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

在上面的例子中,ondrop 屬性調(diào)用了一個(gè)函數(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ù)的默認(rèn)處理(drop 事件的默認(rèn)行為是以鏈接形式打開)

通過 dataTransfer.getData("Text") 方法獲得被拖的數(shù)據(jù)。該方法將返回在 setData() 方法中設(shè)置為相同類型的任何數(shù)據(jù)。

被拖數(shù)據(jù)是被拖元素的 id ("drag1")

把被拖元素追加到放置元素(目標(biāo)元素)中

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對各位學(xué)習(xí)或者使用HTML5能有所幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • 5分鐘弄清楚html5的drag and drop(小結(jié))

    這篇文章主要介紹了5分鐘弄清楚html5的drag and drop(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來
    2019-04-10
  • HTML5 拖放(Drag 和 Drop)詳解與實(shí)例代碼

    本篇文章主要介紹了HTML5 拖放(Drag 和 Drop)詳解與實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-09-14
  • HTML5+CSS3實(shí)現(xiàn)拖放(Drag and Drop)示例

    這篇文章主要為大家介紹了HTML5+CSS3實(shí)現(xiàn)拖放(Drag and Drop)的實(shí)現(xiàn)方法,需要的朋友可以參考下
    2014-07-07
  • 突襲HTML5之Javascript API擴(kuò)展4—拖拽(Drag/Drop)概述

    拖拽(Drag/Drop)是個(gè)非常普遍的功能,可以抓住一個(gè)對象,并且拖動(dòng)到你想放置的區(qū)域;在HTML5中,拖拽(draganddrop)成為了標(biāo)準(zhǔn)操作,任何元素都支持。正因?yàn)檫@個(gè)功能太普遍了
    2013-01-31
  • HTML5 drag和drop具體使用詳解

    這篇文章主要介紹了HTML5 drag和drop具體使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)
    2021-01-18

最新評論