javascript實現完美拖拽效果_javascript技巧

來源:互聯網
上載者:User

拖拽的原理

1.擷取距離(滑鼠的位置-odiv的外邊距)

2.理解什麼時候用onmousemove事件

3.判斷是否過界

html代碼:

<div id="div1"></div>

css代碼:

#div1{width:100px;height:100px;background:red;position:absolute}

javascript代碼:

window.onload=function(){  var oDiv=document.getElementById("div1");  var x=0;  var y=0;  oDiv.onmousedown=function(ev){    var oEvent=ev||event;    //滑鼠的橫座標減去div的offsetLeft    x=oEvent.clientX-oDiv.offsetLeft;    //滑鼠的縱座標減去div的offsetTop    y=oEvent.clientY-oDiv.offsetTop;          document.onmousemove=function(ev){      var oEvent=ev||event;         var left=oEvent.clientX-x;      var right=oEvent.clientY-y;      //判斷左邊是否過界      if(left<0){        left=0;      }      //判斷右邊是否過界      else if(left>document.documentElement.clientWidth-oDiv.offsetWidth){        left=document.documentElement.clientWidth-oDiv.offsetWidth;      }      //判斷上邊是否過界      if(right<0){        right=0;      }      //判斷下邊是否過界      else if(right>document.documentElenment.clientHeight){        right=document.documentElenment.clientHeight-oDiv.offsetHeight;      }      oDiv.style.left=left+"px";      oDiv.style.top=right+"px";    }       document.onmouseup=function(){      //清空document的事件      document.onmousemove=null;      document.onmouseup=null;    }    //解決低版本Firefoxbug,幹掉系統預設    return false;  }}

以上所述就是本文的全部內容了,希望大家能夠喜歡。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.