JavaScript實現拖拽功能

盒子拖拽—運用到的有onmousedown事件,onmousemove事件以及onmouseup事件

1、當鼠標點擊下去的時候我們需要獲取鼠標所在位置的橫縱座標,然後獲取盒子的離頁面的橫縱方向的距離
2、計算出鼠標相對盒子的距離
3、當鼠標移動的時候,獲取鼠標移動的距離,在永鼠標此刻的位置減去鼠標相對盒子的距離,獲得的是盒子此刻的座標位置
4、將這個位置賦值給盒子
5、鼠標擡起,清除鼠標移動事件;

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>鼠標拖拽</title>
    <style>
        .box{
            background-color: pink;
            width:200px;
            height:200px;
            border-radius: 50%;
            position: absolute;
            top:20px;
            left:100px;
        }
    </style>
</head>
<body>
    <div class="box">

    </div>
    <script>
        window.onload = function(){
            var box = document.getElementsByClassName('box')[0];
            function drag (ele){
                ele.onmousedown = function(e){
                    var e = e || window.event;  
                    //此處是爲了兼容IE,因爲IE中事件對象是作爲全局對象( window.event )存在的;
                    var pageX = e.pageX || e.clientX + document.documentElement.scrollLeft;
                    var pageY = e.pageY || e.clientY + document.documentElement.scrollTop;
                    //獲取鼠標相對盒子的位置;
                    var boxX = pageX - box.offsetLeft;
                    var boxY = pageY - box.offsetTop;
                    document.onmousemove = function(e){
                        var e = e || window.event;
                        var pageX = e.pageX || e.clientX + document.documentElement.scrollLeft;
                        var pageY = e.pageY || e.clientY + document.documentElement.scrollTop;
                      //將鼠標當前的座標值減去鼠標相對盒子的位置,得到盒子當時的位置並將其賦值給盒子,實現移動效果
                        box.style.left = pageX - boxX +'px';
                        box.style.top = pageY - boxY + 'px';
                    }
                };
                document.onmouseup = function () {
                    //清除盒子的移動事件;
                    document.onmousemove = null;
                };
            } ;
            drag(box)
        }
    </script>
</body>
</html>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章