Javascript 简单实现鼠标拖动DIV

http://zhangbo-peipei-163-com.iteye.com/blog/1740078

 

比较精简的Javascript拖动效果函数代码

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

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
<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获取页面的各种坐标汇总 

实现拖动: 
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,表示不需要移动DIV
Javascript代码  收藏代码
  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在指定的大小范围内拖动等。
posted @   yufeiyunsui  阅读(438)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示