基于jQuery拖拽事件的封装


Posted in jQuery onNovember 29, 2020

本文实例为大家分享了基于jQuery封装的拖拽事件,供大家参考,具体内容如下

HTML代码:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <script src="jquery-3.4.1.min.js"></script>
  <script src="Drag.js"></script>
  <title>Document</title>
  <style>
    *{
      padding: 0;
      margin: 0;
    }
    .box{
      height: 200px;
      width: 200px;
      background-color: red;
      position: absolute;
      /* 让文字无法被选中 */
      user-select:none;
    }
  </style>
</head>
<body>
  <div class="box"></div>box</div>
  <script>
    $('.box').Drag();//直接调用Drag()方法就可以了
  </script>
</body>
</html>

封装的jQuery拖拽事件:

;(function($) {
  $.fn.extend({
    Drag(){
      //把this存起来,始终指向操作的元素
      _this = this;
      this.on('mousedown',function (e) {
        //盒子距离document的距离
        var positionDiv = $(this).offset();
        //鼠标点击box距离box左边的距离
        var distenceX = e.pageX - positionDiv.left;
        //鼠标点击box距离box上边的距离
        var distenceY = e.pageY - positionDiv.top;
        $(document).mousemove(function(e) {
          //盒子的x轴
          var x = e.pageX - distenceX;
          //盒子的y轴
          var y = e.pageY - distenceY;
          //如果盒子的x轴小于了0就让他等于0(盒子的左边界值)
          if (x < 0) {
            x = 0;
          } 
          //盒子右边界值
          if(x > $(document).width() - _this.outerWidth()){
            x = $(document).width() - _this.outerWidth();
          }
          //盒子的上边界值
          if (y < 0) {
            y = 0;
          }
          //盒子的下边界值
          if(y > $(document).height() - _this.outerHeight()){
            y = $(document).height() - _this.outerHeight();
          }
          //给盒子的上下边距赋值
          $(_this).css({
            'left': x,
            'top': y
          });
        });
        //在页面中当鼠标抬起的时候,就关闭盒子移动事件
        $(document).mouseup(function() {
          $(document).off('mousemove');
        });
      })
      //把this返回回去继续使用jqurey的链式调用
      return this
    }
  })
})(jQuery)

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

jQuery 相关文章推荐
JQuery Ajax 异步操作之动态添加节点功能
May 24 jQuery
JQueryMiniUI按照时间进行查询的实现方法
Jun 07 jQuery
jQuery实现所有验证通过方可提交的表单验证
Nov 21 jQuery
jQuery-ui插件sortable实现自由拖动排序
Dec 01 jQuery
jQuery实现的老虎机跑动效果示例
Dec 29 jQuery
jquery树形插件zTree高级使用详解
Aug 16 jQuery
jquery实现购物车基本功能
Oct 25 jQuery
jquery validate 实现动态增加/删除验证规则操作示例
Oct 28 jQuery
JQuery使用属性addClass、removeClass和toggleClass实现增加和删除类操作示例
Nov 18 jQuery
jQuery实现简单聊天室
Feb 08 jQuery
jQuery 选择方法及$(this)用法实例分析
May 19 jQuery
使用jQuery实现购物车
Oct 29 jQuery
jQuery实现动态操作table行
Nov 23 #jQuery
jQuery-App输入框实现实时搜索
Nov 19 #jQuery
JQuery+drag.js上传图片并且实现图片拖曳
Nov 18 #jQuery
JavaScript枚举选择jquery插件代码实例
Nov 17 #jQuery
如何在vue 中引入使用jquery
Nov 10 #jQuery
jquery实现加载更多&quot;转圈圈&quot;效果(示例代码)
Nov 09 #jQuery
jQuery实现移动端扭蛋机抽奖
Nov 08 #jQuery
You might like
用PHP连接Oracle for NT 远程数据库
2006/10/09 PHP
PHP数组和explode函数示例总结
2015/05/08 PHP
PHP实现全角字符转为半角方法汇总
2015/07/09 PHP
PHP策略模式定义与用法示例
2017/07/27 PHP
网页里控制图片大小的相关代码
2006/06/13 Javascript
收藏一些不常用,但是有用的代码
2007/03/12 Javascript
关于js获取radio和select的属性并控制的代码
2011/05/12 Javascript
JavaScript中的异常捕捉介绍
2014/12/31 Javascript
jquery滚动加载数据的方法
2015/03/09 Javascript
JS实现可点击展开与关闭的左侧广告代码
2015/09/02 Javascript
浅析Bootstrap缩略图组件与警示框组件
2016/04/29 Javascript
AngularJS中过滤器的使用与自定义实例代码
2016/09/17 Javascript
vue.js指令v-model实现方法
2016/12/05 Javascript
iscroll动态加载数据完美解决方法
2017/07/18 Javascript
JavaScript中各数制转换全面总结
2017/08/21 Javascript
vue-resouce设置请求头的三种方法
2017/09/12 Javascript
少女风vue组件库的制作全过程
2019/05/15 Javascript
JS通过ajax + 多列布局 + 自动加载实现瀑布流效果
2019/05/30 Javascript
vue-amap根据地址回显地图并mark的操作
2020/11/03 Javascript
[03:40]DOTA2英雄梦之声_第01期_炼金术士
2014/06/23 DOTA
用python删除java文件头上版权信息的方法
2014/07/31 Python
Python中实现结构相似的函数调用方法
2015/03/10 Python
Python的Flask框架及Nginx实现静态文件访问限制功能
2016/06/27 Python
python实现各进制转换的总结大全
2017/06/18 Python
详解如何减少python内存的消耗
2019/08/09 Python
Keras 中Leaky ReLU等高级激活函数的用法
2020/07/05 Python
美国知名奢侈美容品牌零售商:Cos Bar
2017/04/21 全球购物
金融专业个人求职信
2013/09/22 职场文书
村优秀党员事迹材料
2014/01/15 职场文书
餐饮企业总经理岗位职责范文
2014/02/18 职场文书
令人印象深刻的自荐信
2014/05/25 职场文书
2015年药店工作总结
2015/04/20 职场文书
通知函格式范文
2015/04/27 职场文书
学生会宣传部竞选稿
2015/11/21 职场文书
SpringBoot整合Mybatis Generator自动生成代码
2021/08/23 Java/Android
PYTHON使用Matplotlib去实现各种条形图的绘制
2022/03/22 Python