div拖动

<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>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
div拖动是指在网页中,可以使用鼠标来点击并拖动一个div元素,改变它的位置。这通常通过在div元素上添加拖动事件处理程序来实现。当用户点击div元素并移动鼠标时,div元素会跟随鼠标一起移动,直到用户释放鼠标。 实现div拖动的关键是监听鼠标事件,并根据鼠标的位置来改变div元素的位置。当用户按下鼠标时,记录下鼠标的初始位置和div元素的初始位置,并持续监测鼠标的移动。当鼠标移动时,计算鼠标位置的变化,并将div元素的位置相应地进行调整。最后当用户释放鼠标时,停止监测鼠标的移动,并完成div元素的位置改变。这样就实现了div拖动的效果。 div拖动可以给用户带来更好的交互体验,使页面元素的布局更加灵活和个性化。通过div拖动,用户可以自由地调整页面元素的位置,以适应其个人喜好和使用习惯。同时,对于网页设计者来说,div拖动也可以为设计出更加创新和有趣的页面布局提供更多可能性。 在实现div拖动时,需要考虑到用户体验和页面性能等方面的问题。例如,需要合理地控制拖动的范围,避免div元素移出页面边界;还需要优化代码逻辑和减少不必要的重绘,以提高页面的响应速度和用户体验。总而言之,div拖动是一种常见且有趣的网页交互效果,可以通过合理的实现方式为用户带来更好的使用体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值