全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

简单实现js拖拽效果

本文实例为大家分享了js拖拽效果展示的具体代码,供大家参考,具体内容如下

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <style>
    *{
      margin:0;
      padding:0;
    }
    html,body{
      width:100%;
      height:100%;
    }
    #box{
      position:absolute;
      top:50%;
      left:50%;
      width:200px;
      height:200px;
      background:#ff6600;
      margin:-100px 0 0 -100px;
      cursor:move;
      /*
        不知道宽高的情况下的居中
      position:absolute;
      top:0;
      left:0;
      right:0;
      bottom:0;
      margin:auto;
      */  
    }
  </style>
</head>
<body>
  <div id='box'>
    
  </div>
  <script>
    //JS实现让当前的元素在屏幕居中的位置
    var box = document.getElementById('box');
    // box.style.top = ((document.documentElement.clientHeight || document.body.clientHeight)-box.offsetHeight)/2 + "px";

    // box.style.left = ((document.documentElement.clientWidth || document.body.clientWidth)-box.offsetWidth)/2 + "px";
    //拖拽的原理
    /*
      当鼠标在盒子上按下的时候,我们开始拖拽(给盒子绑定onmousemove和onmouseup),当鼠标移动的时候,我们计算盒子的最新位置
      当鼠标抬起的时候说明拖拽结束了,我们的move和up就没用了,我们再把这两个方法移除
    */
    box.onmousedown = down;
    function down(e){
      e = e || window.event;
      //记录开始位置的信息
      this["strX"] = e.clientX;
      this["strY"] = e.clientY;
      this["strL"] = parseFloat(this.style.left);
      this["strT"] = parseFloat(this.style.top);
      //给元素绑定移动和抬起的事件
      if(this.setCapture){
        this.setCapture()//把当前的鼠标和this绑定在一起
        this.onmousemove = move;
        this.onmouseup= up;
      }else{
        var _this = this;
        document.onmousemove = function(e){
          // move(e)//这个里面的this是window
          move.call(_this,e);
        }
          ;
        document.onmouseup= function(e){
          up.call(_this,e);
        };
      }
      
    }
    function move(e){
      e = e || window.event;
      var curL = (e.clientX-this["strX"])+this["strL"];
      var curT = (e.clientY-this["strY"])+this["strT"];
      //边界判断
      var minL = 0,minT = 0,maxL = (document.documentElement.clientWidth || document.body.clientWidth) - this.offsetWidth,maxT = (document.documentElement.clientHeight || document.body.clientHeight) - this.offsetHeight;
      curL = curL < minL ? minL :(curL > maxL ? maxL : curL);
      curT = curT < minT ? minT :(curT > maxT ? maxT : curT)
      this.style.left = curL + "px";
      this.style.top = curT + "px";
    }
    function up(e){
      if(this.releaseCapture){
        this.releaseCapture();//把当前的鼠标和盒子解除绑定
        this.onmousemove = null;
        this.onmouseup= null;
      }else{
        document.onmousemove = null;
        document.onmouseup= null;
        //这样绑定的话,move和up绑定的this都是document
      }
      
    }
    //当鼠标移动过快的时候,我们的鼠标会脱离盒子,导致盒子的mousemove和mouseup事件都移除不到->"鼠标焦点丢失"
    //在IE和火狐浏览器中,我们用一个方法把盒子和鼠标绑定在一起即可。
    //鼠标再快也跑不出去文档:我们把mousemove和mouseup绑定给document
  </script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# js  # 拖拽  # 原生js拖拽实现图形伸缩效果  # 完美实现js拖拽效果 return false用法详解  # js实现本地图片文件拖拽效果  # JS实现简单拖拽效果  # 原生JS实现圆环拖拽效果  # js实现登录框鼠标拖拽效果  # js实现百度登录框鼠标拖拽效果  # 如何实现js拖拽效果及原理解析  # 鼠标  # 绑定  # 当鼠标  # 移除  # 都是  # 这两个  # 就没  # 用了  # 火狐  # 按下  # 大家分享  # 过快  # 再把  # 不出去  # 具体内容  # 大家多多  # 情况下  # 器中  # 文档 


相关文章: 专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  青浦网站制作公司有哪些,苹果官网发货地是哪里?  家具网站制作软件,家具厂怎么跑业务?  南京网站制作费用,南京远驱官方网站?  建站VPS选购需注意哪些关键参数?  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  如何解决VPS建站LNMP环境配置常见问题?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何构建满足综合性能需求的优质建站方案?  济南网站建设制作公司,室内设计网站一般都有哪些功能?  如何通过免费商城建站系统源码自定义网站主题与功能?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  制作网站的模板软件,网站怎么建设?  建站之星好吗?新手能否轻松上手建站?  如何通过二级域名建站提升品牌影响力?  实现点击下箭头变上箭头来回切换的两种方法【推荐】  XML的“混合内容”是什么 怎么用DTD或XSD定义  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  用v-html解决Vue.js渲染中html标签不被解析的问题  ,sp开头的版面叫什么?  学校为何禁止电信移动建设网站?  小型网站建站如何选择虚拟主机?  如何快速搭建自助建站会员专属系统?  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  简历在线制作网站免费,免费下载个人简历的网站是哪些?  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  如何在宝塔面板创建新站点?  建站之星备案流程有哪些注意事项?  如何访问已购建站主机并解决登录问题?  黑客如何通过漏洞一步步攻陷网站服务器?  TestNG的testng.xml配置文件怎么写  建站之星图片链接生成指南:自助建站与智能设计教程  如何零基础在云服务器搭建WordPress站点?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  模具网站制作流程,如何找模具客户?  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  如何在阿里云虚拟服务器快速搭建网站?  高性能网站服务器部署指南:稳定运行与安全配置优化方案  如何选择靠谱的建站公司加盟品牌?  如何通过PHP快速构建高效问答网站功能?  如何快速配置高效服务器建站软件?  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  韩国服务器如何优化跨境访问实现高效连接?  非常酷的网站设计制作软件,酷培ai教育官方网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。