前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >简单的鼠标可拖动DIV 兼容IE/FF

简单的鼠标可拖动DIV 兼容IE/FF

作者头像
书童小二
发布2018-09-03 18:54:13
2.6K0
发布2018-09-03 18:54:13
举报
文章被收录于专栏:前端儿前端儿

一个简单的可拖动div,随着鼠标的移动,div可随之走动

主要思路:

一个div,注册监听onmousedown事件,然后处理获取的对象及其相关值(对象高度,clientX/clientY位置等)

并继而转为监测onmousemove事件,在鼠标移动事件中更新div对象的位置属性

鼠标松开的时候解除监听,更新位置完成。

需要注意的两点

1.更新对象的位置需要用到o.style.left等,这些CSS属性只能内嵌才能被访问到:

代码语言:javascript
复制
<div id="box" style="left:200px;top:200px;"> box </div>

放在<style></style>中是无法访问的,比如:

代码语言:javascript
复制
#box{position: absolute;left:200px;top:200px;width: 200px;}

假如这样做,显示的是无法获取值,请看举例:

代码语言:javascript
复制
//    alert(e.clientX+"  -- " + o.style.left+" -- "+ X);

这样的结果为 :(详情看后边代码)

2. FireFox中是不能直接取event对象的,一般我们都会简单地使用 e = e || event 来区分,其中e是相应于FF中函数的参数部分

比如:

代码语言:javascript
复制
 document.getElementById("box").onmousedown = function(e){ 
        getObject(this,e||event);       //box捕获事件并处理  e-->FF  window.event-->IE
    };

当然有些时候也可以这样考虑:使用全局对象arguments[0]来替代捕获到的事件参数

代码语言:javascript
复制
//    dis = arguments[0]||window.event;   //如果上面那句在FF下无法获取事件,听说可以通过 arguments[0]获取FF下的事件对象

对于拖拽事件这里使用到了另外一种常用的方法:

代码语言:javascript
复制
// document.all(IE)使用setCapture方法绑定;其余比如FF使用Window对象针对事件的捕捉
        document.all?o.setCapture() : window.captureEvents(Event.MOUSEMOVE);  


// document.all(IE)使用releaseCapture解除绑定;其余比如FF使用window对象针对事件的捕捉
        document.all?o.releaseCapture() : window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP)

最后是一个可随鼠标拖动的div

代码,有注释,希望能理解:

代码语言:javascript
复制
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="utf-8">
<title>Examples</title>
<meta name="description" content="">
<meta name="keywords" content="">
<link href="" rel="stylesheet">
<style type="text/css">
    #box{position: absolute;left:200px;top:200px;width: 200px;border:1px solid #333;height: 200px;background-color: #009cc9;text-align: center;}
</style>
</head>
<body>
    <div class="wrap">
        <div id="box" style="left:200px;top:200px;"> box </div>
    </div>
    <script type="text/javascript">
    var o,   //捕获到的事件
          X,  //box水平宽度
          Y;  //box垂直高度
    function getObject(obj,e){    //获取捕获到的对象
        o = obj;
        // document.all(IE)使用setCapture方法绑定;其余比如FF使用Window对象针对事件的捕捉
        document.all?o.setCapture() : window.captureEvents(Event.MOUSEMOVE);  
        X = e.clientX - parseInt(o.style.left);   //获取宽度,
        Y = e.clientY - parseInt(o.style.top);   //获取高度,
    //    alert(e.clientX+"  -- " + o.style.left+" -- "+ X);
    }
    document.getElementById("box").onmousedown = function(e){ 
        getObject(this,e||event);       //box捕获事件并处理  e-->FF  window.event-->IE
    };
    document.onmousemove = function(dis){    //鼠标移动事件处理
        if(!o){    //如果未获取到相应对象则返回
            return;
        }
        if(!dis){  //事件
            dis = event ;
        //    dis = arguments[0]||window.event;   //如果上面那句在FF下无法获取事件,听说可以通过 arguments[0]获取FF下的事件对象
        }
        o.style.left = dis.clientX - X +"px";     //设定box样式随鼠标移动而改变
        o.style.top = dis.clientY - Y + "px";
    };
    document.onmouseup = function(){    //鼠标松开事件处理
        if(!o){   //如果未获取到相应对象则返回
            return;
        }
        // document.all(IE)使用releaseCapture解除绑定;其余比如FF使用window对象针对事件的捕捉
        document.all?o.releaseCapture() : window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP)
        o = '';   //还空对象
    };
    </script>
</body>
</html>
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015-03-21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档