溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

怎么用HTML5+CSS3實(shí)現(xiàn)拖放功能

發(fā)布時(shí)間:2021-09-01 17:08:54 來(lái)源:億速云 閱讀:108 作者:chen 欄目:web開(kāi)發(fā)

這篇文章主要介紹“怎么用HTML5+CSS3實(shí)現(xiàn)拖放功能”,在日常操作中,相信很多人在怎么用HTML5+CSS3實(shí)現(xiàn)拖放功能問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”怎么用HTML5+CSS3實(shí)現(xiàn)拖放功能”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

本文簡(jiǎn)單介紹一下HTML5的拖放實(shí)現(xiàn)。
拖放(Drag 和 drop)是 HTML5 標(biāo)準(zhǔn)的組成部分。
瀏覽器支持:Internet Explorer 9、Firefox、Opera 12、Chrome 以及 Safari 5 支持拖放。

被拖元素,dragElement :
(1)添加事件:ondragstart
(2)添加屬性:dragable

放置元素,dropElement:
1、添加事件:ondargenter , ondragover , ondragleave , ondragend ,ondrop
和mouser劃入劃出一類(lèi)的事件很類(lèi)似,字面也很好理解,不贅述了,下面會(huì)用例子來(lái)說(shuō)明。

2、頁(yè)面上元素間的拖放
下面用個(gè)小例子,div間的拖放來(lái)展示,各個(gè)事件如何被觸發(fā):

代碼如下:

<html>
   <title></title>
   <meta charset="utf-8">
   <style type="text/css">
       #dropEle
       div
       {
           float: left;
       }
   </style>
   <script src="./js/jquery-1.8.3.js" type="text/javascript" charset="utf-8"></script>
   <script type="text/javascript">
       /**
        * 拖放(Drag 和 drop)是 HTML5 標(biāo)準(zhǔn)的組成部分。
        * 瀏覽器支持
        *Internet Explorer 9、Firefox、Opera 12、Chrome 以及 Safari 5 支持拖放。
        */
       $(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))
            * @param event
            */
           $("#dropEle")[0].ondrop = function (event)
           {
            /*   for (var p in event.dataTransfer)
               {
                   console.log(p + " = " + event.dataTransfer[p] + " @@");
               }
           */
               console.log("onDrop");
               var id = 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("onDrop over");
               event.preventDefault();
           }
           $("#dropEle")[0].ondragenter = function (event)
           {
               console.log("onDrop enter");
           }
           $("#dropEle")[0].ondragleave = function (event)
           {
               console.log("onDrop leave");
           }
           $("#dropEle")[0].ondragend = function (event)
           {
               console.log("onDrop end");
           }
       });
   </script>
<div  draggable="true" id="dragEle">
</div>
<div  id="dropEle"></div>

系統(tǒng)中選擇的一個(gè)或多個(gè)文件拖入該div中,files中會(huì)存儲(chǔ)拖入文件的信息,然后我們通過(guò)file可以得到文件的類(lèi)型,長(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分別是拖入元素的類(lèi)型,拖拽過(guò)程中鼠標(biāo)顯示的樣式,不過(guò)通常可以忽略這幾個(gè)屬性,一般用不到。

到此,關(guān)于“怎么用HTML5+CSS3實(shí)現(xiàn)拖放功能”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI