国产视频app今天接到一個小小的需求,就是利用 JS 來實現鼠標拖動一個div,來實現其位置的改變。雖然說要求看著很簡單,但實現起來還是比較難一點的,下面就說說實現的方法!

js實現鼠標拖動div改變其位置的方法

先上個圖示,大家看一下效果!

102.gif

js實現鼠標拖動的div的代碼

html完整代碼

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            width: 100px;
            height: 100px;
            text-align: center;
            line-height: 100px;
            color:aliceblue;
            margin-right: 10px; 
        }
    </style>
</head>
<body>
    <div draggable="true" style="background-color: #E91E63;">div1</div>
    <div draggable="true"  style="background-color: green;">div2</div>
    <div draggable="true"  style="background-color: #ccc;">div3</div>
<script>
    div = document.getElementsByClassName('ws');
    container = null;
    for(let i=0;i<div.length;i++){
        div[i].ondragstart = function(){
            container = this;
        }
        div[i].ondragover = function(){
            event.preventDefault();
        }
        div[i].ondrop = function(){
            if(container != null && container != this){
                temp = document.createElement('div');
                document.body.replaceChild(temp,this);
                document.body.replaceChild(this, container);
                document.body.replaceChild(container, temp);
            }
        }
    }
</script>
</body>
</html>

注意要點:

国产视频app1、被移動元素的 draggable 屬性一直要設置為 true

国产视频app2、移動到的位置,一定要有一個指定的范圍,不然會報錯

国产视频app3、上面的示例采用的是元素替換的方法

DIV draggable 屬性小解

国产视频appdraggable:屬性規定元素是否可拖動。

語法:

<p draggable="true">這是一個可拖動的段落。</p>

注:拖動div元素的效果,需要配合js來實現!