简单实现js拖拽效果

发布时间 - 2026-01-11 02:30:29    点击率:

本文实例为大家分享了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拖拽效果及原理解析  # 鼠标  # 绑定  # 当鼠标  # 移除  # 都是  # 这两个  # 就没  # 用了  # 火狐  # 按下  # 大家分享  # 过快  # 再把  # 不出去  # 具体内容  # 大家多多  # 情况下  # 器中  # 文档 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何集成Inertia.js与Vue/React?(安装配置)  简单实现jsp分页  Laravel如何为API生成Swagger或OpenAPI文档  零基础网站服务器架设实战:轻量应用与域名解析配置指南  Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布  HTML 中如何正确使用模板变量为元素的 name 属性赋值  如何挑选高效建站主机与优质域名?  ,网页ppt怎么弄成自己的ppt?  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  如何撰写建站申请书?关键要点有哪些?  ,交易猫的商品怎么发布到网站上去?  原生JS获取元素集合的子元素宽度实例  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  实现点击下箭头变上箭头来回切换的两种方法【推荐】  Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法  大型企业网站制作流程,做网站需要注册公司吗?  清除minerd进程的简单方法  Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】  Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能  Laravel如何使用查询构建器?(Query Builder高级用法)  高端建站如何打造兼具美学与转化的品牌官网?  如何快速查询域名建站关键信息?  Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南  如何用AI帮你把自己的生活经历写成一个有趣的故事?  网站图片在线制作软件,怎么在图片上做链接?  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化  详解MySQL数据库的安装与密码配置  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  图册素材网站设计制作软件,图册的导出方式有几种?  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  高防服务器租用如何选择配置与防御等级?  Linux网络带宽限制_tc配置实践解析【教程】  网站制作软件有哪些,制图软件有哪些?  Laravel用户密码怎么加密_Laravel Hash门面使用教程  JavaScript如何操作视频_媒体API怎么控制播放  Python文件操作最佳实践_稳定性说明【指导】  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  如何在橙子建站上传落地页?操作指南详解  laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法  Android使用GridView实现日历的简单功能  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  微信推文制作网站有哪些,怎么做微信推文,急?  Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧  Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  Laravel如何实现模型的全局作用域?(Global Scope示例)  php json中文编码为null的解决办法  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  如何用PHP快速搭建CMS系统?