欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

html5拖拽應(yīng)用記錄及注意點

  發(fā)布時間:2020-05-27 15:09:07   作者:佚名   我要評論
這篇文章主要介紹了html5拖拽應(yīng)用記錄,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

下面通過代碼給大家介紹html5拖拽應(yīng)用記錄,具體代碼如下所示:

e.dataTransfer.setData("a","設(shè)置的值");
e.dataTransfer.getData("a");
function drop(e)
{
    <!--嘗試console.log(e),這里能拿到好多你用得到的api-->
    e.dataTransfer.setData("a", e.target.id);
}

拖動元素

被拖動的元素上要加入入draggable="true"屬性

一些注意點:

drop 必須配上 dragover,否則事件不生效

document.getElementById('right').ondragover = function (ev) {
    ev.preventDefault(); //阻止向上冒泡
}
document.getElementById('right').ondrop = function (ev) {
    ev.preventDefault(); //阻止向上冒泡
    console.log("放入");
}

react中使用事件必須是駝峰,例如:onDragOver

vue中在ui庫組件上加的時候記得加 .native,例如:@drop.native

完整測試案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        .div1{
            width: 200px;
            height: 200px;
            border: 1px solid red;
            position: relative;
            margin-left:20px;
            float: left;
        }
        .div2{
            width: 200px;
            height: 200px;
            border: 1px solid blue;
            position: relative;
            margin-left:20px;
            float: left;
        }
        .div3{
            width: 200px;
            height: 200px;
            border: 1px solid green;
            position: relative;
            margin-left:20px;
            float: left;
        }
        p{
            background-color: orange;
            margin-top: 5px;
        }
    </style>
</head>
<body>
<div class="div1" id="div1">
    <!--在h5中,如果想拖拽元素,就必須為元素添加draggable="true". 圖片和超鏈接默認(rèn)就可以拖拽-->
    <p id="pe" draggable="true">試著把我拖過去</p>
    <p id="pe1" draggable="true">試著也把我拖過去</p>
</div>
<div class="div2" id="div2"></div>
<div class="div3" id="div3"></div>
<script>
    /*學(xué)習(xí)拖拽,主要就是學(xué)習(xí)拖拽事件*/
    var p=document.querySelector("#pe1");
    var div2=document.querySelector("#div2");
    var div3=document.querySelector("#div3");
    /*應(yīng)用于被拖拽元素的事件
    *ondrag         應(yīng)用于拖拽元素,整個拖拽過程都會調(diào)用--持續(xù)
     ondragstart    應(yīng)用于拖拽元素,當(dāng)拖拽開始時調(diào)用
     ondragleave    應(yīng)用于拖拽元素,當(dāng)鼠標(biāo)離開拖拽元素時調(diào)用
     ondragend    應(yīng)用于拖拽元素,當(dāng)拖拽結(jié)束時調(diào)用*/
    p.ondragstart=function(e){
        console.log("開始");
        e.dataTransfer.setDate("a")
    }
    p.ondragend=function(){
        console.log("結(jié)束");
    }
    p.ondragleave=function(){
        console.log("離開目標(biāo)");
    }
    p.ondrag=function(){
        // console.log("持續(xù)觸發(fā)---111111");
    }
 
    /*應(yīng)用于目標(biāo)元素的事件
    *ondragenter    應(yīng)用于目標(biāo)元素,當(dāng)拖拽元素進(jìn)入時調(diào)用
     ondragover    應(yīng)用于目標(biāo)元素,當(dāng)停留在目標(biāo)元素上時調(diào)用
     ondrop        應(yīng)用于目標(biāo)元素,當(dāng)在目標(biāo)元素上松開鼠標(biāo)時調(diào)用
     ondragleave    應(yīng)用于目標(biāo)元素,當(dāng)鼠標(biāo)離開目標(biāo)元素時調(diào)用*/
    div2.ondragenter=function(){
        console.log("進(jìn)入目標(biāo)1");
    }
    div2.ondragover=function(e){
        console.log(e);
        console.log("在目標(biāo)1中盤旋");
        //console.log("ondragover");
        /*如果想觸發(fā)ondrop事件,那么就必須在這個位置阻止瀏覽器的默認(rèn)行為*/
        e.preventDefault();
    }
    /*瀏覽器默認(rèn)會阻止ondrop事件:我們必須在ondragover中阻止瀏覽器的默認(rèn)行為*/
    div2.ondrop=function(){
        console.log("鎖定目標(biāo)1,降落");
        /*添加被拖拽的元素到當(dāng)前目標(biāo)元素*/
        div2.appendChild(p);
    }
    div2.ondragleave=function(){
        console.log("離開目標(biāo)1");
    }

    div3.ondragenter=function(){
        console.log("進(jìn)入目標(biāo)2");
    }
 
    div3.ondragover=function(e){
        console.log("在目標(biāo)2中盤旋");
        //console.log("ondragover");
        /*如果想觸發(fā)ondrop事件,那么就必須在這個位置阻止瀏覽器的默認(rèn)行為*/
        e.preventDefault();
    }
    div3.ondrop=function(){
        console.log("鎖定目標(biāo)2,降落");
        /*添加被拖拽的元素到當(dāng)前目標(biāo)元素*/
        div3.appendChild(p);
    }
    div3.ondragleave=function(){
        console.log("離開目標(biāo)2");
    }
</script>
</body>
</html>

總結(jié)

到此這篇關(guān)于html5拖拽應(yīng)用記錄的文章就介紹到這了,更多相關(guān)html5拖拽應(yīng)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

相關(guān)文章

  • HTML5實現(xiàn)拖拽互動改變元素顏色特效

    一個拖拽改變背顏色的特效,拖動左邊的顏色放到所需要改變顏色的字體或背景上就可以實現(xiàn)背景改變顏色,炫酷實用,歡迎下載
    2020-09-16
  • 基于Html5實現(xiàn)的react拖拽排序組件示例

    這篇文章主要介紹了基于Html5實現(xiàn)的react拖拽排序組件示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-13
  • HTML5拖拽功能實現(xiàn)的拼圖游戲

    本文通過實例代碼給大家介紹了HTML5拖拽功能實現(xiàn)的拼圖游戲,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-07-31
  • html5 拖拽及用 js 實現(xiàn)拖拽功能的示例代碼

    這篇文章主要介紹了html5 拖拽及用 js 實現(xiàn)拖拽,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-23

最新評論