全网整合营销服务商

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

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

利用JavaScript实现拖拽改变元素大小

大致介绍

拖拽改变元素大小是在模拟拖拽上增加了一些功能

拖拽改变元素大小原理

首先这个方块得知道我们想要改变这个它的大小,所以我给它设定一个范围,当点击这个范围时表明我们想要改变它的大小

当我们点击方块的这些红色区域时,方快就知道我们想要改变它的大小

代码实现:

// 获取event对象,兼容性写法
      var ev = ev || event;
      // 鼠标按下时的位置
      var mouseDownX = ev.clientX;
      var mouseDownY = ev.clientY;
      // 方块上下左右四个边的位置和方块的长宽
      var T0 = this.offsetTop;
      var B0 = this.offsetTop + this.offsetHeight;
      var L0 = this.offsetLeft;
      var R0 = this.offsetLeft + this.offsetWidth;
      var W = this.offsetWidth;
      var H = this.offsetHeight;
      // 设置方块的识别范围
      var areaT = T0 + 10;
      var areaB = B0 - 10;
      var areaL = L0 + 10;
      var areaR = R0 - 10;

其中areaT、areaB、areaL、areaR就是红色的区域

接下来方块知道我们想要改变它的大小了,但是要怎么改变,朝哪种方向改变大小。所以要判断改变大小的方向

代码实现:

// 判断改变方块的大小的方向
      // 左
      var changeL = mouseDownX < areaL;
      // 右
      var changeR = mouseDownX > areaR;
      // 上
      var changeT = mouseDownY < areaT;
      // 下
      var changeB = mouseDownY > areaB;

接下来就是最重要的改变样式了

代码实现:

//根据改变方块大小的方向不同进行大小的改变
        // 左
        if(changeL){
          oDiv.style.width = (mouseDownX - mouseMoveX) + W + 'px';
          oDiv.style.left = L0 - (mouseDownX - mouseMoveX) + 'px';
        }
        // 右
        if(changeR){
          oDiv.style.width = (mouseMoveX - mouseDownX) + W + 'px';
        }
        // 上
        if(changeT){
          oDiv.style.height = (mouseDownY - mouseMoveY) + H + 'px';
          oDiv.style.top = T0 - (mouseDownY - mouseMoveY) + 'px';
        }
        // 下
        if(changeB){
          oDiv.style.height = (mouseMoveY - mouseDownY) + H +'px';
        }

注意:在改变左侧和上侧时要同时修改方块的位置,不然会出现拖左侧边而右侧边位置扩大的现象(拖动上侧边下侧边位置变大)

代码优化

未优化前的代码:

var oDiv = document.getElementById('div1');
    oDiv.onmousedown = function(ev){
      // 获取event对象,兼容性写法
      var ev = ev || event;
      // 鼠标按下时的位置
      var mouseDownX = ev.clientX;
      var mouseDownY = ev.clientY;
      // 方块上下左右四个边的位置和方块的长宽
      var T0 = this.offsetTop;
      var B0 = this.offsetTop + this.offsetHeight;
      var L0 = this.offsetLeft;
      var R0 = this.offsetLeft + this.offsetWidth;
      var W = this.offsetWidth;
      var H = this.offsetHeight;
      // 设置方块的识别范围
      var areaT = T0 + 10;
      var areaB = B0 - 10;
      var areaL = L0 + 10;
      var areaR = R0 - 10;
      // 判断改变方块的大小的方向
      // 左
      var changeL = mouseDownX < areaL;
      // 右
      var changeR = mouseDownX > areaR;
      // 上
      var changeT = mouseDownY < areaT;
      // 下
      var changeB = mouseDownY > areaB;
      oDiv.onmousemove = function(ev){
        var ev = ev || event;
        // 鼠标移动时的鼠标位置
        var mouseMoveX = ev.clientX;
        var mouseMoveY = ev.clientY;
        //根据改变方块大小的方向不同进行大小的改变
        // 左
        if(changeL){
          oDiv.style.width = (mouseDownX - mouseMoveX) + W + 'px';
          oDiv.style.left = L0 - (mouseDownX - mouseMoveX) + 'px';
        }
        // 右
        if(changeR){
          oDiv.style.width = (mouseMoveX - mouseDownX) + W + 'px';
        }
        // 上
        if(changeT){
          oDiv.style.height = (mouseDownY - mouseMoveY) + H + 'px';
          oDiv.style.top = T0 - (mouseDownY - mouseMoveY) + 'px';
        }
        // 下
        if(changeB){
          oDiv.style.height = (mouseMoveY - mouseDownY) + H +'px';
        }
        // 限定范围
        if(parseInt(oDiv.style.width) < 50){
          oDiv.style.width = 50 + 'px';
        }
        if(parseInt(oDiv.style.height) < 50){
          oDiv.style.height = 50 + 'px';
        }
      }
      oDiv.onmouseup = function(){
        oDiv.onmousemove = null;
      }
    }

这段代码现在主要有两个问题:

1、当鼠标移动过快移出方块时,就不能够继续改变元素的大小了

  解决方案:把onmousemove事件和onmouseup事件绑定到document对象上

2、当方块中有文字时,拖拽改变方块大小时会触发浏览器默认的原生拖放行为

  解决方案:1、阻止浏览器的默认行为(IE8浏览器除外)

         在onmousedown中添加语句 return false

      2、设置全局捕获(IE8)

         在onmousedown中设置全局捕获

         在onmouseup中取消全局捕获 

优化后的代码:

<div id="div1">adfadsf</div>
  <script type="text/javascript">
    var oDiv = document.getElementById('div1');
    oDiv.onmousedown = function(ev){
      // 获取event对象,兼容性写法
      var ev = ev || event;
      // 鼠标按下时的位置
      var mouseDownX = ev.clientX;
      var mouseDownY = ev.clientY;
      // 方块上下左右四个边的位置和方块的长宽
      var T0 = this.offsetTop;
      var B0 = this.offsetTop + this.offsetHeight;
      var L0 = this.offsetLeft;
      var R0 = this.offsetLeft + this.offsetWidth;
      var W = this.offsetWidth;
      var H = this.offsetHeight;
      // 设置方块的识别范围
      var areaT = T0 + 10;
      var areaB = B0 - 10;
      var areaL = L0 + 10;
      var areaR = R0 - 10;
      // 判断改变方块的大小的方向
      // 左
      var changeL = mouseDownX < areaL;
      // 右
      var changeR = mouseDownX > areaR;
      // 上
      var changeT = mouseDownY < areaT;
      // 下
      var changeB = mouseDownY > areaB;
      // IE8 取消默认行为-设置全局捕获
      if(oDiv.setCapture){
        oDiv.setCapture();
      }
      document.onmousemove = function(ev){
        var ev = ev || event;
        // 鼠标移动时的鼠标位置
        var mouseMoveX = ev.clientX;
        var mouseMoveY = ev.clientY;
        //根据改变方块大小的方向不同进行大小的改变
        // 左
        if(changeL){
          oDiv.style.width = (mouseDownX - mouseMoveX) + W + 'px';
          oDiv.style.left = L0 - (mouseDownX - mouseMoveX) + 'px';
        }
        // 右
        if(changeR){
          oDiv.style.width = (mouseMoveX - mouseDownX) + W + 'px';
        }
        // 上
        if(changeT){
          oDiv.style.height = (mouseDownY - mouseMoveY) + H + 'px';
          oDiv.style.top = T0 - (mouseDownY - mouseMoveY) + 'px';
        }
        // 下
        if(changeB){
          oDiv.style.height = (mouseMoveY - mouseDownY) + H +'px';
        }
        // 限定范围
        if(parseInt(oDiv.style.width) < 50){
          oDiv.style.width = 50 + 'px';
        }
        if(parseInt(oDiv.style.height) < 50){
          oDiv.style.height = 50 + 'px';
        }
      }
      document.onmouseup = function(){
        document.onmousemove = null;
        // 释放全局捕获
        if(oDiv.releaseCapture){
          oDiv.releaseCapture();
        }
      }
      return false;
    }

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# js  # 拖拽  # javascript  # vuejs2.0运用原生js实现简单拖拽元素功能  # vuejs2.0运用原生js实现简单的拖拽元素功能示例  # JavaScript实现拖拽元素对齐到网格(每次移动固定距离)  # jquery插件jquery.dragscale.js实现拖拽改变元素大小的方法(附demo源码下载  # JavaScript实现拖拽网页内元素的方法  # javascript实现拖拽并替换网页块元素  # js实现拖拽元素选择和删除  # 鼠标  # 上下左右  # 按下  # 长宽  # 是在  # 就不  # 最重要  # 中有  # 这段  # 当我们  # 拖动  # 哪种  # 过快  # 时要  # 绑定  # 给它  # 变大  # 拖放  # 增加了 


相关文章: 小说建站VPS选用指南:性能对比、配置优化与建站方案解析  建站VPS推荐:2025年高性能服务器配置指南  如何通过二级域名建站提升品牌影响力?  如何设置并定期更换建站之星安全管理员密码?  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  建站主机无法访问?如何排查域名与服务器问题  如何通过VPS建站无需域名直接访问?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  Python lxml的etree和ElementTree有什么区别  如何在IIS中配置站点IP、端口及主机头?  建站ABC备案流程中有哪些关键注意事项?  宝塔新建站点为何无法访问?如何排查?  文字头像制作网站推荐软件,醒图能自动配文字吗?  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  网站制作难吗安全吗,做一个网站需要多久时间?  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  如何用wdcp快速搭建高效网站?  智能起名网站制作软件有哪些,制作logo的软件?  制作网站的过程怎么写,用凡科建站如何制作自己的网站?  如何快速搭建响应式可视化网站?  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  网站制作大概多少钱一个,做一个平台网站大概多少钱?  C#怎么使用委托和事件 C# delegate与event编程方法  如何彻底删除建站之星生成的Banner?  建站OpenVZ教程与优化策略:配置指南与性能提升  如何通过wdcp面板快速创建网站?  高防服务器如何保障网站安全无虞?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  高端建站三要素:定制模板、企业官网与响应式设计优化  再谈Python中的字符串与字符编码(推荐)  公司网站制作价格怎么算,公司办个官网需要多少钱?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成  如何快速生成ASP一键建站模板并优化安全性?  外贸公司网站制作,外贸网站建设一般有哪些步骤?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  如何选择域名并搭建高效网站?  如何通过山东自助建站平台快速注册域名?  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  建站之星代理费用多少?最新价格详情介绍  小型网站建站如何选择虚拟主机?  香港服务器部署网站为何提示未备案?  如何快速查询域名建站关键信息? 

您的项目需求

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