這篇文章主要為大家介紹了HTML5+CSS3實(shí)現(xiàn)拖放(DragandDrop)的實(shí)現(xiàn)方法,需要的朋友可以參考下。
本文簡單介紹一下HTML5的拖放實(shí)現(xiàn)。
拖放(Drag和drop)是HTML5標(biāo)準(zhǔn)的組成部分。
瀏覽器支持:InternetExplorer9、Firefox、Opera12、Chrome以及Safari5支持拖放。
被拖元素,dragElement:
(1)添加事件:ondragstart
(2)添加屬性:dragable
放置元素,dropElement:
1、添加事件:ondargenter,ondragover,ondragleave,ondragend,ondrop
和mouser劃入劃出一類的事件很類似,字面也很好理解,不贅述了,下面會用例子來說明。
2、頁面上元素間的拖放
下面用個小例子,div間的拖放來展示,各個事件如何被觸發(fā):
代碼如下:
<html>
<title></title>
<metacharset="utf-8">
<styletype="text/css">
#dropEle
div
{
float:left;
}
</style>
<scriptsrc="./js/jquery-1.8.3.js"type="text/javascript"charset="utf-8"></script>
<scripttype="text/javascript">
/**
*拖放(Drag和drop)是HTML5標(biāo)準(zhǔn)的組成部分。
*瀏覽器支持
*InternetExplorer9、Firefox、Opera12、Chrome以及Safari5支持拖放。
*/
$(function()
{
$("#dragEle")[0].ondragstart=function(event)
{
console.log("dragStart");
event.dataTransfer.setData("Text",event.target.id);
};
/**
*當(dāng)放置被拖數(shù)據(jù)時,會發(fā)生drop事件。
*調(diào)用preventDefault()來避免瀏覽器對數(shù)據(jù)的默認(rèn)處理(drop事件的默認(rèn)行為是以鏈接形式打開)
*@paramevent
*/
$("#dropEle")[0].ondrop=function(event)
{
/*for(varpinevent.dataTransfer)
{
console.log(p+"="+event.dataTransfer[p]+"@@");
}
*/
console.log("onDrop");
varid=event.dataTransfer.getData("Text");
$(this).append($("#"+id).clone().text($(this).find("div").length));
event.preventDefault();
};
/**
*ondragover事件規(guī)定在何處放置被拖動的數(shù)據(jù)。
*默認(rèn)地,無法將數(shù)據(jù)/元素放置到其他元素中。如果需要設(shè)置允許放置,我們必須阻止對元素的默認(rèn)處理方式。
*/
$("#dropEle")[0].ondragover=function(event)
{
console.log("onDropover");
event.preventDefault();
}
$("#dropEle")[0].ondragenter=function(event)
{
console.log("onDropenter");
}
$("#dropEle")[0].ondragleave=function(event)
{
console.log("onDropleave");
}
$("#dropEle")[0].ondragend=function(event)
{
console.log("onDropend");
}
});
</script>
<divstyle="border:1pxsolidred;width:100px;height:100px;text-align:center;line-height:100px;"draggable="true"id="dragEle">
</div>
<divstyle="width:330px;min-height:202px;border:1pxsolid#444;margin-top:20px;overflow-y:scroll;"id="dropEle"></div>
系統(tǒng)中選擇的一個或多個文件拖入該div中,files中會存儲拖入文件的信息,然后我們通過file可以得到文件的類型,長度,內(nèi)容然后實(shí)現(xiàn)上傳。
3、setDragImage(image,x,y)用于設(shè)置鼠標(biāo)移動過程中隨鼠標(biāo)一起移動的效果圖。必須在dragstart中設(shè)置。
4、types,effectAllowed和dropEffect分別是拖入元素的類型,拖拽過程中鼠標(biāo)顯示的樣式,不過通??梢院雎赃@幾個屬性,一般用不到。
更多信息請查看IT技術(shù)專欄