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 相关文章推荐
网页里控制图片大小的相关代码
Jun 13 Javascript
用Javascript实现UTF8编码转换成gb2312编码
Dec 22 Javascript
文本链接逐个出现的js脚本
Dec 12 Javascript
关于Ext中form移除textfield方法:hide(),setVisible(false),remove()
Dec 02 Javascript
IE6背景图片不缓存问题解决方案及图片使用策略多个方法小结
May 14 Javascript
JS对文本框值的判断示例
Mar 10 Javascript
JavaScript控制各种浏览器全屏模式的方法、属性和事件介绍
Apr 03 Javascript
使用jquery+CSS3实现仿windows10开始菜单的下拉导航菜单特效
Sep 24 Javascript
javascript使用 concat 方法对数组进行合并的方法
Sep 08 Javascript
JavaScript初学者必看“new”
Jun 12 Javascript
JavaScript箭头函数_动力节点Java学院整理
Jun 28 Javascript
express如何解决ajax跨域访问session失效问题详解
Jun 20 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(1)
2006/10/09 PHP
做个自己站内搜索引擎
2006/10/09 PHP
PHP中for循环语句的几种变型
2007/03/16 PHP
php 多个submit提交表单 处理方法
2009/07/07 PHP
PHP分页类集锦
2014/11/18 PHP
php合并数组并保留键值的实现方法
2018/03/12 PHP
jQuery技巧大放送 学习jquery的朋友可以看下
2009/10/14 Javascript
Javascript继承机制的设计思想分享
2011/08/28 Javascript
javascript学习笔记(一)基础知识
2014/09/30 Javascript
轻松掌握jQuery中wrap()与unwrap()函数的用法
2016/05/24 Javascript
node.js 动态执行脚本
2016/06/02 Javascript
jQuery实现两个select控件的互移操作
2016/12/22 Javascript
vue2.0嵌套路由实现豆瓣电影分页功能(附demo)
2017/03/13 Javascript
使用vue.js写一个tab选项卡效果
2017/03/25 Javascript
JS交互点击WKWebView中的图片实现预览效果
2018/01/05 Javascript
浅谈Vue路由快照实现思路及其问题
2018/06/07 Javascript
Vue插件打包与发布的方法示例
2018/08/20 Javascript
移动端滑动切换组件封装 vue-swiper-router实例详解
2018/11/25 Javascript
微信小程序如何实现精确的日期时间选择器
2020/01/21 Javascript
vue页面更新patch的实现示例
2020/03/25 Javascript
Postman如何实现参数化执行及断言处理
2020/07/28 Javascript
一个简单的python程序实例(通讯录)
2013/11/29 Python
python使用WMI检测windows系统信息、硬盘信息、网卡信息的方法
2015/05/15 Python
Django基于ORM操作数据库的方法详解
2018/03/27 Python
Python功能点实现:函数级/代码块级计时器
2019/01/02 Python
centos7中安装python3.6.4的教程
2019/12/11 Python
Python MySQLdb 执行sql语句时的参数传递方式
2020/03/04 Python
Django模型验证器介绍与源码分析
2020/09/08 Python
python爬取代理IP并进行有效的IP测试实现
2020/10/09 Python
Farfetch香港官网:汇集全球时尚奢侈品购物平台
2017/11/26 全球购物
2014年两会学习心得范例
2014/03/17 职场文书
利群广告词
2014/03/20 职场文书
走群众路线剖析材料
2014/10/09 职场文书
庆祝教师节主持词
2015/07/06 职场文书
Python使用UDP实现720p视频传输的操作
2021/04/24 Python
MySQL之MyISAM存储引擎的非聚簇索引详解
2022/03/03 MySQL