html5+css3實(shí)現(xiàn)拖放(dragdrop)示例

字號(hào):


    這篇文章主要為大家介紹了html5+css3實(shí)現(xiàn)拖放(draganddrop)的實(shí)現(xiàn)方法,需要的朋友可以參考下。
    本文簡(jiǎ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劃入劃出一類的事件很類似,字面也很好理解,不贅述了,下面會(huì)用例子來(lái)說(shuō)明。
    2、頁(yè)面上元素間的拖放
    下面用個(gè)小例子,div間的拖放來(lái)展示,各個(gè)事件如何被觸發(fā):
    代碼如下:
    <html>
    <title></title>
    <metacharset=utf-8>
    <styletype=text/css>
    #dropele
    div
    {
    float:left;
    }
    </style>
    <scriptsrc=./js/jquery-1.8.3.jstype=text/javascriptcharset=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ù)時(shí),會(huì)發(fā)生drop事件。
    *調(diào)用preventdefault()來(lái)避免瀏覽器對(duì)數(shù)據(jù)的默認(rèn)處理(drop事件的默認(rèn)行為是以鏈接形式打開(kāi))
    *@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ī)定在何處放置被拖動(dòng)的數(shù)據(jù)。
    *默認(rèn)地,無(wú)法將數(shù)據(jù)/元素放置到其他元素中。如果需要設(shè)置允許放置,我們必須阻止對(duì)元素的默認(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=trueid=dragele>
    </div>
    <divstyle=width:330px;min-height:202px;border:1pxsolid#444;margin-top:20px;overflow-y:scroll;id=dropele></div>
    系統(tǒng)中選擇的一個(gè)或多個(gè)文件拖入該div中,files中會(huì)存儲(chǔ)拖入文件的信息,然后我們通過(guò)file可以得到文件的類型,長(zhǎng)度,內(nèi)容然后實(shí)現(xiàn)上傳。
    3、setdragimage(image,x,y)用于設(shè)置鼠標(biāo)移動(dòng)過(guò)程中隨鼠標(biāo)一起移動(dòng)的效果圖。必須在dragstart中設(shè)置。
    4、types,effectallowed和dropeffect分別是拖入元素的類型,拖拽過(guò)程中鼠標(biāo)顯示的樣式,不過(guò)通??梢院雎赃@幾個(gè)屬性,一般用不到。