成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > HTML5 拖放(Drag 和 Drop)詳解與實例代碼

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

熱門標(biāo)簽:當(dāng)涂高德地圖標(biāo)注 黃島區(qū)地圖標(biāo)注 電銷機器人電話用什么卡 鎮(zhèn)江智能外呼系統(tǒng)有效果嗎 南寧點撥外呼系統(tǒng)哪家公司做的好 云南大理400電話申請官方 成都智能外呼系統(tǒng)平臺 四川點撥外呼系統(tǒng) 江蘇智能電銷機器人哪家好

簡介

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

在 HTML5 中,拖放是標(biāo)準(zhǔn)的一部分,任何元素都能夠拖放。

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

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

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

定義和用法

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

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

拖拽前的頁面效果為:

 

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

設(shè)置元素可拖放

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

<img draggable="true">

拖動什么 - ondragstart 和 setData()

然后,規(guī)定當(dāng)元素被拖動時,會發(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ù)。

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

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

event.preventDefault()

進(jìn)行放置 - ondrop

當(dāng)放置被拖數(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ù)的默認(rèn)處理(drop 事件的默認(rèn)行為是以鏈接形式打開)
  • 通過 dataTransfer.getData("Text") 方法獲得被拖的數(shù)據(jù)。該方法將返回在 setData() 方法中設(shè)置為相同類型的任何數(shù)據(jù)。
  • 被拖數(shù)據(jù)是被拖元素的 id ("drag1")
  • 把被拖元素追加到放置元素(目標(biāo)元素)中

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

 

dataTransfer對象

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

對象屬性:

  • dropEffect:設(shè)置或返回拖放目標(biāo)上允許發(fā)生的拖放行為。如果此處設(shè)置的拖放行為不再effectAllowed屬性設(shè)置的多種拖放行為之內(nèi),拖放操作將會失敗。該屬性值只允許為“null”、“copy”、“link”和“move”四值之一。
  • effectAllowed:設(shè)置或返回被拖動元素允許發(fā)生的拖動行為。該屬性值可設(shè)為“none”、“copy”、“copyLink”、“copyMove”、“link”、“linkMove”、“move”、“all”和“uninitialized”。
  • items:該屬性返回DataTransferItems對象,該對象代表了拖動數(shù)據(jù)。
  • types:該屬性返回一個DOMStringList對象,該對象包括了存入dataTransfer中數(shù)據(jù)的所有類型。

對象方法:

  • setData(format,data):將指定格式的數(shù)據(jù)賦值給dataTransfer對象,參數(shù)format定義數(shù)據(jù)的格式也就是數(shù)據(jù)的類型,data為待賦值的數(shù)據(jù)
  • getData(format):從dataTransfer對象中獲取指定格式的數(shù)據(jù),format代表數(shù)據(jù)格式,data為數(shù)據(jù)。
  • clearData([format]):從dataTransfer對象中刪除指定格式的數(shù)據(jù),參數(shù)可選,若不給出,則為刪除對象中所有的數(shù)據(jù)。
  • addElement(element):添加自定義圖標(biāo)
  • setDragImage(element,x,y):設(shè)置拖放操作的自定義圖標(biāo)。其中element設(shè)置自定義圖標(biāo),x設(shè)置圖標(biāo)與鼠標(biāo)在水平方向上的距離,y設(shè)置圖標(biāo)與鼠標(biāo)在垂直方向上的距離。

Identify what is draggable

function dragstart_handler(ev) {
 console.log("dragStart");
 // Add the target element's id to the data transfer object
 ev.dataTransfer.setData("text/plain", ev.target.id);
}

<body>
 <p id="p1" draggable="true" ondragstart="dragstart_handler(event);">This element is draggable.</p>
</body>

Define the drag's data

function dragstart_handler(ev) {
  // Add the drag data
  ev.dataTransfer.setData("text/plain", ev.target.id);
  ev.dataTransfer.setData("text/html", "<p>Example paragraph</p>");
  ev.dataTransfer.setData("text/uri-list", "http://developer.mozilla.org");
}

Define the drag image

function dragstart_handler(ev) {
  // Create an image and then use it for the drag image.
  // NOTE: change "example.gif" to an existing image or the image 
  // will not be created and the default drag image will be used.
  var img = new Image(); 
  img.src = 'example.gif'; 
  ev.dataTransfer.setDragImage(img, 10, 10);
}

Define the drag effect

function dragstart_handler(ev) {
  // Set the drag effect to copy
  ev.dataTransfer.dropEffect = "copy";
}

Define a drop zone

function dragover_handler(ev) {
 ev.preventDefault();
 // Set the dropEffect to move
 ev.dataTransfer.dropEffect = "move"
}
function drop_handler(ev) {
 ev.preventDefault();
 // Get the id of the target and add the moved element to the target's DOM
 var data = ev.dataTransfer.getData("text");
 ev.target.appendChild(document.getElementById(data));
}
<body>
 <div id="target" ondrop="drop_handler(event);" ondragover="dragover_handler(event);">Drop Zone</div>
</body>

火狐瀏覽器拖拽問題

但是進(jìn)行到這兒在火狐瀏覽器中發(fā)現(xiàn)一個問題:

html5的拖拽,用了preventDefault防止彈出新頁面,但在火狐下不管用?

解決辦法:

document.body.ondrop = function (event) {
    event.preventDefault();
    event.stopPropagation();
} 

或者對于上面的實例中,添加到ondrop方法里面也是可以的:

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:南京 佳木斯 西寧 十堰 酒泉 咸寧 廣西 淮安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML5 拖放(Drag 和 Drop)詳解與實例代碼》,本文關(guān)鍵詞  HTML5,拖放,Drag,和,Drop,詳解,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《HTML5 拖放(Drag 和 Drop)詳解與實例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于HTML5 拖放(Drag 和 Drop)詳解與實例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合亚洲| 奇米四色中文综合久久| 蜜桃av久久久亚洲精品| 免费亚洲一区| 欧美一区二区不卡视频| 成人综合婷婷国产精品久久| 色婷婷久久久综合中文字幕| 欧美伦理免费在线| 久久亚洲国产精品成人av秋霞| 日本成年免费网站| 性感美女一级片| 亚洲免费一区| 日本一区二区三区在线免费观看| 中文在线观看免费高清| 中文字幕一区二区三区人妻四季| 久久久久久亚洲综合影院红桃| 日韩在线观看一区二区| 又大又长粗又爽又黄少妇视频| www.久久com| 日本午夜精品理论片a级appf发布| 国精品**一区二区三区在线蜜桃| 精品福利在线看| 亚洲国产精品一区二区第一页| 色婷婷综合久色| 国产日韩在线播放| 免费污污网站| 中文字幕乱码av| 国产一区二区三区免费播放| 欧美色一级片| 国产精品视频二区三区| 三级电影在线看| 一级网站在线观看| 欧亚一区二区三区| 亚洲一区二区免费看| 中文字幕精品久久久| 成人免费毛片播放| 日韩网站在线播放| 中文字幕视频在线免费欧美日韩综合在线看| 国产剧情麻豆剧果冻传媒视频免费| 在线观看视频一区二区欧美日韩| 草草视频在线观看| 日韩a∨精品日韩在线观看| 三级在线看中文字幕完整版| 韩日欧美一区二区三区| 91tv精品福利国产在线观看| 日韩欧美中文字幕在线观看| 肥臀熟女一区二区三区| 国产精品19p| 黄视频网站免费看| 精品中文字幕在线| 91精品国产乱码久久久久久久| 欧美久久久一区| 亚洲精品国产精品乱码在线观看| 国产ts一区| 亚洲免费在线视频观看| 一区二区福利| 国产精品久久一级| 一区二区三区欧美在线| 国产精品免费91| 乱人伦中文字幕在线zone| 国产美女免费视频| 好吊妞视频一区二区三区| 欧美日韩激情在线观看| 国产在线98福利播放视频| 女生影院久久| 麻豆精品国产传媒| 日本高清视色| 欧美熟妇另类久久久久久多毛| 国产精品久久福利| 四虎国产精品成人免费入口| 黄色在线观看国产| 亚洲激情视频一区| 黄视频网站在线看| 好吊日在线视频| 日韩精品一区二区在线播放| 亚洲在线日韩| 亚洲人成久久| 亚洲aa中文字幕| 亚洲小视频网站| 久久国产精品首页| 国产男女无遮挡| 欧美视频成人| 一级毛片免费看| 一级做a爰片久久毛片美女图片| 中文字幕第50页| 激情欧美一区二区三区黑长吊| 日韩av综合网站| 国产精品久久久久久久岛一牛影视| 国产美女久久| 韩国三级av在线免费观看| 同性视频网站免费男| 欧美亚洲一区二区三区四区| 午夜精品无码一区二区三区| 一二三区高清| 国产一级片av| 成年人小视频在线观看| 亚洲a一区二区三区| 中文在线观看视频| 日韩在线免费观看视频| 日本三级电影在线播放| h无码动漫在线观看| 国产剧情一区| 亚洲高清国产拍精品26u| 欧美日本国产精品| 日韩欧美另类在线| 国产一区二区三区av电影| 在线免费观看一级片| 国产精品久久久久久久一区二区| 欧美区日韩区| 国产麻豆精品久久一二三| 娇妻被老王脔到高潮失禁视频| 亚洲欧美激情在线| 国产激情91久久精品导航| 69sex久久精品国产麻豆| 久久 天天综合| 亚洲黄在线观看| 日韩视频一二区| 女人18毛片水真多免费播放| 欧美a级在线| 免费精品一区二区三区在线观看| ass大特写| 美女网站视频黄色| 久久久久久国产精品| 欧美国产日韩在线观看| 国产日产精品一区二区三区的介绍| 99国产精品久久久久久久| 国产九九视频一区二区三区| 三妻四妾的电影电视剧在线观看| 色琪琪免费视频网站| 日韩精品另类天天更新| 欧美一级欧美三级在线观看| 精品国产一区二区三区麻豆小说| 欧美精品三级日韩久久| 四虎国产精品永久| 国产又黄又爽又无遮挡| 成人高潮aa毛片免费| 亚洲午夜激情影院| 中文无字幕一区二区三区| 亚洲成人日韩| 国产精品久久久久久久久久久久久久久久| 在线观看av网| 超碰97av在线| 丰满岳乱妇一区二区| 欧美做爰性欧美大fennong| 成人在线一区二区| 亚洲精品国产suv一区88| 麻豆av在线播放| 欧美一区二区高清在线观看| 欧美一级欧美三级在线观看| 三级网站在线| 国产在线999| 一区二区三区| 久久婷婷一区| 成人看片网页| 中文乱码字幕高清一区二区| 亚洲欧洲另类国产综合| 日本久久网站| 黄色免费网址大全| 美腿丝袜在线亚洲一区| 亚洲午夜久久久久久久久电影网| 日本不卡一区二区三区高清视频| 99re6热在线精品视频播放| 99久热re在线精品996热视频| 天堂а√在线8种子蜜桃视频| 中文字幕一区二区三| 性欧美黑人xxxx| 青青草成人在线观看| 国产精品美女久久久久av爽| 精品国产一区久久久| 欧美性69xxxx肥| a视频在线观看免费| 女人在下体塞跳蛋在线观看| 日本一区二区三区视频免费看| 精品一区二区国产| h免费在线观看| 久久精品一区二区三区av| 93在线视频精品免费观看| 欧美视频在线第一页| av成人app永久免费| 99精品人妻国产毛片| www.男人的天堂.com| 香港三级经典全部种子下载| 欧美一级做a| 91九色在线观看视频| 中文字幕乱在线伦视频中文字幕乱码在线| 欧美日韩亚洲精品内裤| 日本不卡一二三区| 欧美人与性囗牲恔配| 国产一区二区在线观看免费视频| 欧美三级电影精品| 精华区一区二区三区| 欧美成人四级hd版| 国产探花视频在线播放| 亚洲福利专区| 午夜私人影院在线观看| 亚洲成人精品久久| 成网站在线观看人免费| 亚洲成人精品久久| 一区二区三区四区免费| 给我免费播放片在线观看| 国产精品后入内射日本在线观看| 欧美videossex极品| 一色屋色费精品视频在线观看| 亚洲成人免费电影| 国产精品无码一区二区三区免费| 岛国视频午夜一区免费在线观看| 久久久国产成人精品| 国产精品蜜臀在线观看| 男人舔女人下部高潮全视频| 国产精品久久精品牛牛影视| 亚洲福利视频二区| 国模私拍国内精品国内av| 亚洲图片欧洲图片av| 经典一区二区三区| 丁香婷婷综合激情五月色| 日韩三级电影网| 五月婷婷一区二区三区| 欧美一级淫片aaaaaaa视频| 国产精品久久久久久久久晋中| 美女免费观看一区二区三区| 永久免费黄色片| 伊人久久亚洲热| 国产精品jk白丝蜜臀av小说| 三级福利片在线观看| 99se婷婷在线视频观看| 免费黄视频网站| 伊人影院在线视频| 午夜精品视频一区| 国产网站在线看| 欧美一级片在线观看| 国产不卡网站| 香蕉视频黄色在线观看| 欧美特级黄色片| 久久精品国产综合| 性视频一区二区三区| 一区二区日韩| 亚洲另类在线视频| 亚洲色大成网站www| 日韩美女免费观看| 欧美大片免费观看网址| 制服丝袜亚洲色图| 国产三级第一页| 日韩精品在线视频免费观看| 91视频在线视频| 另类少妇人与禽zozz0性伦| 亚洲电影在线一区二区三区| 视色,视色影院,视色影库,视色网| 污视频在线免费观看网站| 日韩伦理电影网站| 禁断一区二区三区在线| 国产精品99视频| 国产成人精品综合久久久| 久久久久久久久久久久久女国产乱| 日本aⅴ大伊香蕉精品视频| 男操女视频网站| 国精产品999国精产品官网| 一二三在线视频| 亚洲人成77777在线观看网| 国产精品自拍偷拍视频| 91精品韩国| 伊人成人开心激情综合网| 日韩精品电影一区二区| 夜夜狂射影院| 日本一区二区三区四区在线观看| 国内在线免费高清视频| 欧美日韩福利在线观看| 国 产 黄 色 大 片| 国产免费不卡av| 久久天堂夜夜一本婷婷麻豆| 亚洲线精品一区二区三区八戒| 国产探花在线观看| 怡红院在线播放| 欧美日韩三级电影在线| av一区二区三区四区电影| 中文字幕有码在线视频| 亚洲成人黄色网址| 神马影视一区二区| 九九视频精品全部免费播放| 日韩日韩日韩日韩| 国产一区二区三区高清| 一级片视频网站| 成人av蜜桃| 国产综合色在线观看| 波多野结衣电影在线播放| 亚洲精选av在线| 首播影院在线观看免费观看电视| 日韩在线视频中文字幕| caopon在线免费视频| 欧美另类z0zx974| 欧美成人性生活视频| 日本美女一级片| 亚州欧美一区三区三区在线| 搞黄视频免费在线观看| 国产在线看片免费视频在线观看| 最近中文字幕在线| 亚洲a级黄色片| 久久久无码中文字幕久...| 成人精品中文字幕| 97久久超碰| 360天大佬第二季在线观看| 日本高清+成人网在线观看| 古装做爰无遮挡三级聊斋艳谭| av第一福利在线导航| 青春草国产成人精品久久| 蜜臀精品一区二区| 国产乱码在线观看| 四虎海外影库www4hu| 久久久性生活视频| 91色在线播放| 特黄特色免费视频| 羞羞视频网站| 久久综合九色综合久| 欧美mv和日韩mv国产网站| xx00欧美| 亚洲一区二区三区四区在线| 欧美色涩在线第一页| 99re8这里有精品热视频免费| 亚洲毛片播放| 麻豆精品蜜桃视频网站| 久久久免费看片| 国产免费叼嘿网站免费| 中文字幕精品久久久| 成人少妇影院yyyy| 精品国产乱码久久久久久丨区2区| 国产日韩欧美电影在线观看| 在线中文字幕-区二区三区四区| 成人国产精品免费观看视频| 国产精品白浆流出视频|