標籤:
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拖動DIV Javascript簡單的實現滑鼠拖動DIV的效果。沒有什麼技術含量,全當筆記。
要想實現滑鼠拖動效果,免不了要計算元素在瀏覽器中的座標,那首先來學習一下各種座標。
參考:
Javascript擷取頁面的各種座標匯總
實現拖動:
1.定義需要的變數
Javascript代碼
- var bool=false,
- pageX=0,
- pageY=0,
-
- //需要拖動的目標DIV
- element = $("#tb_window"),
- eWidth = element.width(),
- eHeight = element.height(),
-
- //在該DIV的範圍內拖動
- pElement = $("#flashFrame"),
- pWidth = pElement.width(),
- pHeight = pElement.height();
2.滑鼠mousedown事件計算滑鼠焦點x相對目標DIV的座標
Javascript代碼
- element.mousedown(function(event)
- {
- needMove=true;
- var position = element.position();
- pageX = event.pageX-position.left; //滑鼠和DIV的相對座標
- pageY = event.pageY-position.top;
-
- element.css(‘cursor‘,‘move‘);
- });
3.滑鼠mouseup事件將變數needMove賦值false,表示不需要移動DIVJavascript代碼
- element.mouseup(function(event)
- {
- needMove=false;
- });
4.滑鼠的mousemove事件開始移動目標DIV
Javascript代碼
- element.mousemove(function(event)
- {
- if(!needMove) {return;}
-
- //滑鼠在頁面的座標 - 滑鼠和DIV的相對座標 = DIV在頁面的座標
- var ePageX = event.pageX;
- var ePageY = event.pageY;
-
- var x = ePageX-pageX;
- var y = ePageY-pageY;
- if (ePageX <= eWidth/ 2 || ePageX >= pWidth - eWidth / 2)
- {
- return;
- }
-
- if (ePageY< eHeight / 2 || ePageY >= pHeight - eHeight / 2)
- {
- return;
- }
- element.css("left", x);
- element.css("top", y);
- });
5.總結,以上代碼只是簡單實現滑鼠拖動DIV的思路(當然功能也是可以的),具體的效能,相容性和代碼擴充性都有待商榷。比如:還可以增加參數控制DIV在指定的大小範圍內拖動等。
Javascript 簡單實現滑鼠拖動DIV