Javascript 簡單實現滑鼠拖動DIV

來源:互聯網
上載者:User

標籤:

http://zhangbo-peipei-163-com.iteye.com/blog/1740078 比較精簡的Javascript拖動效果函數代碼

http://www.jb51.net/article/10578.htm

 
<html>  <head><title>拖動效果函數示範 by Longbill.cn</title>  <style>  body   {      font-size:12px;      color:#333333;      border : 0px solid blue;  }  div  {      position : absolute;      background-color : #c3d9ff;      margin : 0px;      padding : 5px;      border : 0px;      width : 100px;      height:100px;  }  </style>  </head>  <body>  <script>  function drag(o,s)  {      if (typeof o == "string") o = document.getElementById(o);      o.orig_x = parseInt(o.style.left) - document.body.scrollLeft;      o.orig_y = parseInt(o.style.top) - document.body.scrollTop;      o.orig_index = o.style.zIndex;                o.onmousedown = function(a)      {          this.style.cursor = "move";          this.style.zIndex = 10000;          var d=document;          if(!a)a=window.event;          var x = a.clientX+d.body.scrollLeft-o.offsetLeft;          var y = a.clientY+d.body.scrollTop-o.offsetTop;          //author: www.longbill.cn          d.ondragstart = "return false;"          d.onselectstart = "return false;"          d.onselect = "document.selection.empty();"                            if(o.setCapture)              o.setCapture();          else if(window.captureEvents)              window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);          d.onmousemove = function(a)          {              if(!a)a=window.event;              o.style.left = a.clientX+document.body.scrollLeft-x;              o.style.top = a.clientY+document.body.scrollTop-y;              o.orig_x = parseInt(o.style.left) - document.body.scrollLeft;              o.orig_y = parseInt(o.style.top) - document.body.scrollTop;          }          d.onmouseup = function()          {              if(o.releaseCapture)                  o.releaseCapture();              else if(window.captureEvents)                  window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);              d.onmousemove = null;              d.onmouseup = null;              d.ondragstart = null;              d.onselectstart = null;              d.onselect = null;              o.style.cursor = "normal";              o.style.zIndex = o.orig_index;          }      }            if (s)      {          var orig_scroll = window.onscroll?window.onscroll:function (){};          window.onscroll = function ()          {              orig_scroll();              o.style.left = o.orig_x + document.body.scrollLeft;              o.style.top = o.orig_y + document.body.scrollTop;          }      }  }  </script>  <div id="div1" style="left:10px;top:10px;">div1:我可以被拖動</div>  <div id="div2" style="left:120px;top:10px;background-color : #f3d9ff">div2:來拖我呀</div>  <div id="div3" style="left:230px;top:10px;background-color : #c3ffff">div3:我隨便你拖</div>  <div id="div4" style="left:10px;top:120px;background-color : #c3d944">div4:我可以隨視窗滑動,把我拖到最下面,然後滾動網頁看看</div>  <div id="div5" style="left:120px;top:120px;background-color : #f3d944">作者: Longbill<a href=http://www.longbill.cn target=_blank>www.longbill.cn</a>  </div>  <div id="div6" style="left:230px;top:120px;background-color : #e3f944;width:200px;">參數說明:  drag(obj [,scroll]);  obj:對象的id或對象本身;  scroll(可選):對象是否隨視窗拖動而滑動,預設為否  滑鼠右鍵查看原始碼  </div>  <script>  drag("div1");  drag("div2");  drag("div3");  drag("div4",1);  drag("div5",1);  drag("div6",1);  </script>  </body> 

  

avascript 簡單實現滑鼠拖動DIV 部落格分類:
     
  • Javascript
javascript拖動DIV Javascript簡單的實現滑鼠拖動DIV的效果。沒有什麼技術含量,全當筆記。 
要想實現滑鼠拖動效果,免不了要計算元素在瀏覽器中的座標,那首先來學習一下各種座標。 
參考: 
Javascript擷取頁面的各種座標匯總 

實現拖動: 
1.定義需要的變數 
Javascript代碼  
  1. var bool=false,         
  2. pageX=0,          
  3. pageY=0,     
  4.   
  5. //需要拖動的目標DIV  
  6. element = $("#tb_window"),  
  7. eWidth = element.width(),  
  8. eHeight = element.height(),  
  9.   
  10. //在該DIV的範圍內拖動  
  11. pElement = $("#flashFrame"),  
  12. pWidth = pElement.width(),  
  13. pHeight = pElement.height();  


2.滑鼠mousedown事件計算滑鼠焦點x相對目標DIV的座標 
Javascript代碼  
  1. element.mousedown(function(event)  
  2. {  
  3.     needMove=true;               
  4.     var position = element.position();  
  5.     pageX = event.pageX-position.left; //滑鼠和DIV的相對座標  
  6.     pageY = event.pageY-position.top;  
  7.             
  8.     element.css(‘cursor‘,‘move‘);       
  9. });  


3.滑鼠mouseup事件將變數needMove賦值false,表示不需要移動DIVJavascript代碼  
  1. element.mouseup(function(event)  
  2. {              
  3.     needMove=false;    
  4. });  


4.滑鼠的mousemove事件開始移動目標DIV 
Javascript代碼  
  1. element.mousemove(function(event)  
  2. {              
  3.     if(!needMove) {return;}     
  4.       
  5.     //滑鼠在頁面的座標 - 滑鼠和DIV的相對座標 = DIV在頁面的座標          
  6.      var ePageX = event.pageX;      
  7.     var ePageY = event.pageY;  
  8.    
  9.     var x = ePageX-pageX;              
  10.     var y = ePageY-pageY;      
  11.     if (ePageX <= eWidth/ 2 || ePageX >= pWidth - eWidth / 2)  
  12.     {  
  13.         return;  
  14.     }  
  15.    
  16.     if (ePageY< eHeight / 2 || ePageY >= pHeight - eHeight / 2)  
  17.     {  
  18.         return;  
  19.     }             
  20.     element.css("left", x);              
  21.     element.css("top", y);    
  22. });    


5.總結,以上代碼只是簡單實現滑鼠拖動DIV的思路(當然功能也是可以的),具體的效能,相容性和代碼擴充性都有待商榷。比如:還可以增加參數控制DIV在指定的大小範圍內拖動等。

Javascript 簡單實現滑鼠拖動DIV

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.