溫馨提示×

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

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

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

發(fā)布時(shí)間:2021-08-07 16:57:49 來(lái)源:億速云 閱讀:149 作者:Leah 欄目:web開(kāi)發(fā)

本篇文章給大家分享的是有關(guān)HTML5 中怎么實(shí)現(xiàn)拖放功能,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

1、拖放 

  1. <!DOCTYPE HTML>  

  2. <html>  

  3. <head>  

  4. <style type="text/css">  

  5. #div1 {width:350px;height:70px;padding:10px;border:1px solid #aaaaaa;}   

  6. </style>  

  7. <script>  

  8. function allowDrop(ev)   

  9. {   

  10. ev.preventDefault();   

  11. }   

  12. function drag(ev)   

  13. {   

  14. ev.dataTransfer.setData("Text",ev.target.id);   

  15. }   

  16. function drop(ev)   

  17. {   

  18. ev.preventDefault();   

  19. var data=ev.dataTransfer.getData("Text");   

  20. ev.target.appendChild(document.getElementById(data));   

  21. }   

  22. </script>  

  23. </head>  

  24. <body>  

  25. <p>拖動(dòng) W3CSchool.cc 圖片到矩形框中:</p>  

  26. <div id="div1" ondrop="drop(event)" ondragover="allowDrop(event)"></div>  

  27. <br>  

  28. <img id="drag1" src="/images/logo.png" draggable="true" ondragstart="drag(event)" width="336" height="69">  

  29. </body>  

  30. </html>   

2、設(shè)置元素為可拖放
 
首先,為了使元素可拖動(dòng),把 draggable 屬性設(shè)置為 true :<img draggable="true">
 
3、拖動(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ù)類(lèi)型和值:

JavaScript Code復(fù)制內(nèi)容到剪貼板

  1. function drag(ev)   

  2. {   

  3.    ev.dataTransfer.setData("Text",ev.target.id);   

  4. }    

在這個(gè)例子中,數(shù)據(jù)類(lèi)型是 "Text",值是可拖動(dòng)元素的 id ("drag1")。
 
4、放到何處 - ondragover
 
ondragover 事件規(guī)定在何處放置被拖動(dòng)的數(shù)據(jù)。默認(rèn)地,無(wú)法將數(shù)據(jù)/元素放置到其他元素中。如果需要設(shè)置允許放置,我們必須阻止對(duì)元素的默認(rèn)處理方式。這要通過(guò)調(diào)用 ondragover 事件的 event.preventDefault() 方法:event.preventDefault()
 
5、進(jìn)行放置 - ondrop
 
 當(dāng)放置被拖數(shù)據(jù)時(shí),會(huì)發(fā)生 drop 事件。在上面的例子中,ondrop 屬性調(diào)用了一個(gè)函數(shù),drop(event):

JavaScript Code復(fù)制內(nèi)容到剪貼板

  1. function drop(ev)   

  2. {   

  3. ev.preventDefault();   

  4. var data=ev.dataTransfer.getData("Text");   

  5. ev.target.appendChild(document.getElementById(data));   

  6. }    

代碼解釋?zhuān)?/span>

調(diào)用 preventDefault() 來(lái)避免瀏覽器對(duì)數(shù)據(jù)的默認(rèn)處理(drop 事件的默認(rèn)行為是以鏈接形式打開(kāi))。通過(guò) dataTransfer.getData("Text") 方法獲得被拖的數(shù)據(jù)。該方法將返回在 setData() 方法中設(shè)置為相同類(lèi)型的任何數(shù)據(jù)。被拖數(shù)據(jù)是被拖元素的 id ("drag1")。把被拖元素追加到放置元素(目標(biāo)元素)中。

以上就是HTML5 中怎么實(shí)現(xiàn)拖放功能,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

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

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎ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