jQuery窗口拖动功能的实现代码


Posted in Javascript onFebruary 04, 2017

jQuery窗口拖动功能的实现代码

具体代码如下所示:

$("#showTitle").mousedown(function (e) {
    vbool = true;
    vHeight = e.pageY;
    vWidth = e.pageX;
    cHeight = vHeight - $("#show").offset().top;
    cWdith = vWidth - $("#show").offset().left;
    //alert("divshow" + $("#show").offset().top + " divvHeight" + vHeight);
    //alert("高" + cHeight + " 宽" + cWdith);
  })
  $(document).mouseup(function () {
    vbool = false;
  })
  var showWidth = $("#show").width();
  var showHeight = $("#show").height();
  var documentWidth = $(document).width();
  var documentHeight = $(document).height();
  $(document).mousemove(function (e) {
    if (vbool) {
      var divheight = e.pageY - cHeight;//窗口要移动到的位置
      var divwidth = e.pageX - cWdith;//窗口要移动到的位置
      $("#la1").text(divheight + "w" + divwidth + "win" + showWidth + " x " + documentWidth + "" + showWidth);
      if (divwidth < 0) {
        divwidth = 0;
      }
      if (divheight < 50) {
        divheight = 50;
      }
      if (divwidth > documentWidth - showWidth) {
        divwidth = documentWidth - showWidth - 5;
      }
      if (divheight > documentHeight - showHeight) {
        divheight = documentHeight - showHeight - 5;
      }
      $("#show").css({ "left": divwidth, "top": divheight });
    }
  })

下面看下jQuery 鼠标拖拽移动窗口的实现代码

拖拽移动需要注意的是:拖拽移动的窗口是如何定位的,如果"left"属性为"%" ,以"margin-left"来计算定位,如下实例,如果"left"属性为数字,直接使用"left"即可。

// 弹窗模块拖拽拖动
$(function(){
  var _move=false;//移动标记
  var _x,_y;//鼠标离控件左上角的相对位置
  var _dragZone = $(".M_boxCenter .M_boxBody > h3");
  var _dragBody = _dragZone.parent();
  _dragZone.mousedown(function(e){
    $(this).attr("onselectstart", "return false"); //禁双击选中
    $("body").css({"-webkit-user-select":"none", "-moz-user-select":"none", "-ms-user-select":"none", "-khtml-user-select":"none", "user-select":"none"}); //禁止选中文字
    _move=true;
    _x=e.pageX-parseInt(_dragBody.css("margin-left"));
    _y=e.pageY-parseInt(_dragBody.css("margin-top"));
    _dragBody.fadeTo(150, 0.5);
  });
  $(document).mousemove(function(e){
    if(_move){
      var x=e.pageX-_x;//移动时根据鼠标位置计算控件左上角的绝对位置
      var y=e.pageY-_y;
      if(e.pageX <= 0 || e.pageY <= 0){
        _move=false;
      }else {
        _dragBody.css({marginLeft:x, marginTop:y});//控件新位置
      }
    }
  }).mouseup(function(){
    _move=false;
    _dragBody.fadeTo("fast", 1);
    $("body").removeAttr("style"); //移除不能选文字
  });
});

以上所述是小编给大家介绍的jQuery窗口拖动功能的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript 导出数据到Excel(处理table中的元素)
Dec 18 Javascript
基于jQuery的仿flash的广告轮播代码
Nov 04 Javascript
jQuery的链式调用浅析
Dec 03 Javascript
修复ie8&amp;chrome下window的resize事件多次执行
Oct 20 Javascript
使用jquery菜单插件HoverTree仿京东无限级菜单
Dec 18 Javascript
如何解决vue与传统jquery插件冲突
Mar 20 Javascript
JavaScript数据类型和变量_动力节点Java学院整理
Jun 26 Javascript
vue.js组件vue-waterfall-easy实现瀑布流效果
Aug 22 Javascript
javascript实现文字无缝滚动效果
Aug 26 Javascript
JavaScript的数据类型转换原则(干货)
Mar 15 Javascript
Angular事件之不同组件间传递数据的方法
Nov 15 Javascript
Vue通过getAction的finally来最大程度避免影响主数据呈现问题
Apr 24 Javascript
简单易懂的天气插件(代码分享)
Feb 04 #Javascript
URL中“#” “?” &amp;“”号的作用浅析
Feb 04 #Javascript
Angularjs 依赖压缩及自定义过滤器写法
Feb 04 #Javascript
javascript实现复选框全选或反选
Feb 04 #Javascript
JavaScript获取当前时间向前推三个月的方法示例
Feb 04 #Javascript
javascript表单正则应用
Feb 04 #Javascript
JS中的phototype详解
Feb 04 #Javascript
You might like
PHP常用代码大全(新手入门必备)
2010/06/29 PHP
注意:php5.4删除了session_unregister函数
2013/08/05 PHP
PHP采用自定义函数实现遍历目录下所有文件的方法
2014/08/19 PHP
ecshop 2.72如何修改后台访问地址
2015/03/03 PHP
PHP定时执行任务实现方法详解(Timer)
2015/07/30 PHP
PHP 判断字符串是中文还是英文, 或者是中英混合
2021/03/09 PHP
什么是JavaScript
2009/08/13 Javascript
用console.table()调试javascript
2014/09/04 Javascript
Bootstrap Search Suggest使用例子
2016/12/21 Javascript
react-native ListView下拉刷新上拉加载实现代码
2017/08/03 Javascript
nodejs acl的用户权限管理详解
2018/03/14 NodeJs
vue 录制视频并压缩视频文件的方法
2018/07/27 Javascript
在React项目中使用Eslint代码检查工具及常见问题
2018/10/10 Javascript
angular 用Observable实现异步调用的方法
2018/12/27 Javascript
Node中对非阻塞I/O、事件循环的知识点总结
2020/01/05 Javascript
js实现简单放大镜效果
2020/03/07 Javascript
Vue+ElementUI 中级联选择器Bug问题的解决
2020/07/31 Javascript
Vue+Openlayers自定义轨迹动画
2020/09/24 Javascript
[07:43]《辉夜杯》公开赛晋级外卡赛战队—TRG训练生活探秘
2015/12/11 DOTA
[05:46]2018完美盛典-《同梦共竞》
2018/12/17 DOTA
python里使用正则的findall函数的实例详解
2017/10/19 Python
python 列表,数组,矩阵两两转换tolist()的实例
2018/04/04 Python
对python list 遍历删除的正确方法详解
2018/06/29 Python
pytorch 调整某一维度数据顺序的方法
2018/12/08 Python
ipython jupyter notebook中显示图像和数学公式实例
2020/04/15 Python
使用Python FastAPI构建Web服务的实现
2020/06/08 Python
python+django+selenium搭建简易自动化测试
2020/08/19 Python
HTML5 Canvas实现平移/放缩/旋转deom示例(附截图)
2013/07/04 HTML / CSS
餐厅总厨求职信
2014/03/04 职场文书
实习指导老师评语
2014/04/26 职场文书
销售提升方案
2014/06/07 职场文书
集体生日活动方案
2014/08/18 职场文书
房地产工程部经理岗位职责
2015/04/09 职场文书
承兑汇票延期证明
2015/06/23 职场文书
追讨欠款律师函
2015/06/24 职场文书
基督教追悼会答谢词
2015/09/29 职场文书