js拖拽效果

简介: DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style>
*{margin:0; padding:0;}
#panal{width:200px; height:200px;  position:absolute;  background:#eee; 
display:none;  left:50%; top:50%; margin-left:-100px; margin-top:-100px;
}
#hand{background:deepskyblue; color:white; height:50px; cursor:pointer;}
#close{display:block; width:40px; height:30px; background-color:firebrick; cursor:pointer; color:white; float:right; font-size:10px; text-align:center; line-height:30px;}
</style>
<script>
window.onload=function(){
    var oPanal=document.getElementById('panal');  //弹框面板
  var oClose=document.getElementById('close');   //关闭按钮
  var oShow=document.getElementById('show');   //弹出按钮
  oShow.onclick=function(){  //  点击显示弹框
      oPanal.style.display='block';
  }
  oClose.onclick=function(){   //点击关闭弹窗
      oPanal.style.display='none';
  }
  var oHand=document.getElementById('hand');
  oHand.onmousedown=function(event){   //鼠标按下
      event=event||window.event;
      /*由于起初定位采用了margin,此时重新进行定位*/
      oPanal.style.left=oPanal.offsetLeft+'px';  
      oPanal.style.top=oPanal.offsetTop+'px';   
      oPanal.style.margin=0;  //清除margin
                              
      var oPosx=event.clientX-oPanal.offsetLeft;  // 获取鼠标坐标到弹框左边的距离
      var oPosy=event.clientY-oPanal.offsetTop;   //上边
      
      
      oHand.onmouseup=function(){        // 鼠标抬起取消拖拽
        oHand.onmousemove=null;   
      }
      oHand.onmouseout=function(){        //鼠标移出hand区域取消拖拽
          oHand.onmousemove=null;
      }
      oHand.onmousemove=function(event){    // 鼠标在hand上移动触发
         event=event||window.event;
         var pLeft=event.clientX-oPosx;    //弹框的左边距
         var pTop=event.clientY-oPosy;      //上边距
         
         /*限制弹框的移动距离*/
         var winWidth=document.documentElement.clientWidth || document.body.clientWidth;   //浏览器的窗口长度
         var winHeight=document.documentElement.clientHeight || document.body.clientHeight;
         var maxLeft=winWidth-oPanal.offsetWidth;   //最大的左边距
         var maxTop=winHeight-oPanal.offsetHeight;   //上边距
         
         if(pLeft<0){
             pLeft=0; 
         }else if(pLeft>maxLeft){ 
              pLeft=maxLeft;
         }
         if(pTop<0){
             pTop=0;
         }else if(pTop>maxTop){ 
             pTop=maxTop;
         }
         oPanal.style.left=pLeft+'px';
         oPanal.style.top=pTop+'px';
      }
  }    
}
</script>
</head>

<body>
<div id="panal">
  <h2 id="hand">点击拖拽<span id="close" title="点我关闭弹窗">关闭</span></h2>
</div>
<a href="javascript:;" id="show">拖拽窗口</a>
</body>
</html>

代码是参考的Amy老师的视频,然后写出来的,老师的课程都不错,Amy思路清晰细致

相关文章
|
4月前
|
前端开发 JavaScript
使用JavaScript实现复杂功能:构建一个自定义的拖拽功能
使用JavaScript实现复杂功能:构建一个自定义的拖拽功能
|
1月前
|
JavaScript 调度
Three.js开发秘籍:FlyControls的拖拽视角问题解决方案
Three.js开发秘籍:FlyControls的拖拽视角问题解决方案
40 0
|
3月前
|
JavaScript 前端开发 数据管理
使用Sortable.js库 实现Vue3 elementPlus 的 el-table 拖拽排序
使用Sortable.js库 实现Vue3 elementPlus 的 el-table 拖拽排序
926 1
|
3月前
|
Web App开发 JavaScript 前端开发
一篇文章讲明白js实现移动端拖拽效果
一篇文章讲明白js实现移动端拖拽效果
21 0
|
存储 移动开发 JavaScript
js 拖拽效果实现数据交换(多个元素、可接口请求)
js 拖拽效果实现数据交换(多个元素、可接口请求)
122 0
js 拖拽效果实现数据交换(多个元素、可接口请求)
|
4月前
|
Web App开发 移动开发 JavaScript
一篇文带你使用js实现拖拽排序
一篇文带你使用js实现拖拽排序
|
4月前
|
JavaScript 前端开发
js小功能--如何实现按住shift拖拽多选div
js小功能--如何实现按住shift拖拽多选div
72 0
|
4月前
|
JavaScript 前端开发
JavaScript实现拖拽
JavaScript实现拖拽
|
4月前
|
JavaScript 前端开发
详细讲解原生js拖拽
详细讲解原生js拖拽
|
4月前
|
JavaScript
【经典】原生JS实现“用鼠标拖拽(drag)内容DIV”,滚动条对应同步滚动
【经典】原生JS实现“用鼠标拖拽(drag)内容DIV”,滚动条对应同步滚动