溫馨提示×

溫馨提示×

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

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

html5拖拽應(yīng)用記錄及注意點(diǎn)有哪些

發(fā)布時(shí)間:2021-05-14 10:31:39 來源:億速云 閱讀:135 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了html5拖拽應(yīng)用記錄及注意點(diǎn)有哪些,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

具體代碼如下所示:

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

拖動(dòng)元素

被拖動(dòng)的元素上要加入入draggable="true"屬性

一些注意點(diǎn):

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

 

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

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

vue中在ui庫組件上加的時(shí)候記得加 .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">
    <!--在h6中,如果想拖拽元素,就必須為元素添加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)用于拖拽元素,整個(gè)拖拽過程都會(huì)調(diào)用--持續(xù)
     ondragstart    應(yīng)用于拖拽元素,當(dāng)拖拽開始時(shí)調(diào)用
     ondragleave    應(yīng)用于拖拽元素,當(dāng)鼠標(biāo)離開拖拽元素時(shí)調(diào)用
     ondragend    應(yīng)用于拖拽元素,當(dāng)拖拽結(jié)束時(shí)調(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)入時(shí)調(diào)用
     ondragover    應(yīng)用于目標(biāo)元素,當(dāng)停留在目標(biāo)元素上時(shí)調(diào)用
     ondrop        應(yīng)用于目標(biāo)元素,當(dāng)在目標(biāo)元素上松開鼠標(biāo)時(shí)調(diào)用
     ondragleave    應(yīng)用于目標(biāo)元素,當(dāng)鼠標(biāo)離開目標(biāo)元素時(shí)調(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事件,那么就必須在這個(gè)位置阻止瀏覽器的默認(rèn)行為*/
        e.preventDefault();
    }
    /*瀏覽器默認(rèn)會(huì)阻止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事件,那么就必須在這個(gè)位置阻止瀏覽器的默認(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>

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“html5拖拽應(yīng)用記錄及注意點(diǎn)有哪些”這篇文章對大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

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

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

AI