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 相关文章推荐
原生js实现跨浏览器获取鼠标按键的值
Apr 08 Javascript
修改file按钮的默认样式实现代码
Apr 23 Javascript
javascript 实现 原路返回
Jan 21 Javascript
JavaScript编写推箱子游戏
Jul 07 Javascript
基于Layer+jQuery的自定义弹框
May 26 Javascript
jQuery实现立体式数字动态增加(animate方法)
Dec 21 Javascript
vue-cli axios请求方式及跨域处理问题
Mar 28 Javascript
解决Vue.js由于延时显示了{{message}}引用界面的问题
Aug 25 Javascript
微信小程序与后台PHP交互的方法实例分析
Dec 10 Javascript
JS双向链表实现与使用方法示例(增加一个previous属性实现)
Jan 31 Javascript
React中Ref 的使用方法详解
Apr 28 Javascript
OpenLayers3实现测量功能
Sep 25 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作的文本留言本的例子(二)
2006/10/09 PHP
ThinkPHP的截取字符串函数无法显示省略号的解决方法
2014/06/25 PHP
php向js函数传参的几种方法
2014/08/10 PHP
PHP防止表单重复提交的几种常用方法汇总
2014/08/19 PHP
PHP定时执行任务的3种方法详解
2015/12/21 PHP
php面向对象编程self和static的区别
2016/05/08 PHP
Yii2.0框架模型多表关联查询示例
2019/07/18 PHP
关于laravel后台模板laravel-admin select框的使用详解
2019/10/03 PHP
javascript 表单的友好用户体现
2009/01/07 Javascript
jQuery 1.4 15个你应该知道的新特性(译)
2010/01/24 Javascript
由Javascript实现的页面日历
2011/11/04 Javascript
深入理解JavaScript系列(22):S.O.L.I.D五大原则之依赖倒置原则DIP详解
2015/03/05 Javascript
JavaScript实现向OL列表内动态添加LI元素的方法
2015/03/21 Javascript
js+css实现的圆角边框TAB选项卡滑动门代码分享(2款)
2015/08/26 Javascript
JavaScript实现全选取消效果
2017/12/14 Javascript
深入浅析Node环境和浏览器的区别
2018/08/14 Javascript
分享5个顶级的JavaScript Ajax组件库
2018/09/16 Javascript
使用vue-router切换页面时实现设置过渡动画
2019/10/31 Javascript
原生js实现无缝轮播图
2020/01/11 Javascript
浅谈vue权限管理实现及流程
2020/04/23 Javascript
微信jssdk踩坑之签名错误invalid signature
2020/05/19 Javascript
Javascript执行上下文顺序的深入讲解
2020/11/04 Javascript
vue使用vant中的checkbox实现全选功能
2020/11/17 Vue.js
Vue实现指令式动态追加小球动画组件的步骤
2020/12/18 Vue.js
Python3.4学习笔记之列表、数组操作示例
2019/03/01 Python
python时间序列数据转为timestamp格式的方法
2020/08/03 Python
ffmpeg+Python实现B站MP4格式音频与视频的合并示例代码
2020/10/21 Python
利用纯html5绘制出来的一款非常漂亮的时钟
2015/01/04 HTML / CSS
Canvas 文本填充线性渐变的使用详解
2020/06/22 HTML / CSS
美国按摩椅批发网站:Titan Chair
2018/12/27 全球购物
护理个人求职信范文
2014/01/08 职场文书
社区十八大感言
2014/01/19 职场文书
带刀到教室的检讨书
2014/10/04 职场文书
前台岗位职责
2015/02/13 职场文书
2015新员工工作总结范文
2015/10/15 职场文书
golang 定时任务方面time.Sleep和time.Tick的优劣对比分析
2021/05/05 Golang