首页 > 语言 > JavaScript > 正文

javascript实现完美拖拽效果

2024-05-06 16:19:26
字体:
来源:转载
供稿:网友

javascript实现的拖拽效果,可以把屏幕上的图片拖动到任意地方,效果平滑,点击图片还可以从侧边展开图片的详细信息,非常好的相册效果

拖拽的原理

1.获取距离(鼠标的位置-odiv的外边距)

2.理解什么时候用onmousemove事件

3.判断是否过界

html代码:

 

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

css代码:

 

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

javascript代码:

 

 
  1. window.onload=function(){ 
  2. var oDiv=document.getElementById("div1"); 
  3. var x=0; 
  4. var y=0; 
  5. oDiv.onmousedown=function(ev){ 
  6. var oEvent=ev||event; 
  7. //鼠标的横坐标减去div的offsetLeft 
  8. x=oEvent.clientX-oDiv.offsetLeft; 
  9. //鼠标的纵坐标减去div的offsetTop 
  10. y=oEvent.clientY-oDiv.offsetTop;  
  11.  
  12. document.onmousemove=function(ev){ 
  13. var oEvent=ev||event;  
  14. var left=oEvent.clientX-x; 
  15. var right=oEvent.clientY-y; 
  16. //判断左边是否过界 
  17. if(left<0){ 
  18. left=0; 
  19. //判断右边是否过界 
  20. else if(left>document.documentElement.clientWidth-oDiv.offsetWidth){ 
  21. left=document.documentElement.clientWidth-oDiv.offsetWidth; 
  22. //判断上边是否过界 
  23. if(right<0){ 
  24. right=0; 
  25. //判断下边是否过界 
  26. else if(right>document.documentElenment.clientHeight){ 
  27. right=document.documentElenment.clientHeight-oDiv.offsetHeight; 
  28. oDiv.style.left=left+"px"
  29. oDiv.style.top=right+"px"
  30. }  
  31. document.onmouseup=function(){ 
  32. //清空document的事件 
  33. document.onmousemove=null
  34. document.onmouseup=null
  35. //解决低版本火狐bug,干掉系统默认 
  36. return false

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选