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

来源:http://www.cnblogs.com/imwtr/p/4355416.html

作者:

主要思路:

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

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

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

需要注意的两点

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

<div id="box" style="left:200px;top:200px;"> box </div>

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

#box{position: absolute;left:200px;top:200px;width: 200px;}

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

//    alert(e.clientX+"  -- " + o.style.left+" -- "+ X);

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

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

比如:

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

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

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

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

// 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

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

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 2 <html xmlns="http://www.w3.org/1999/xhtml">
 3 <head>
 4 <meta charset="utf-8">
 5 <title>Examples</title>
 6 <meta name="description" content="">
 7 <meta name="keywords" content="">
 8 <link href="" rel="stylesheet">
 9 <style type="text/css">
10     #box{position: absolute;left:200px;top:200px;width: 200px;border:1px solid #333;height: 200px;background-color: #009cc9;text-align: center;}
11 </style>
12 </head>
13 <body>
14     <div class="wrap">
15         <div id="box" style="left:200px;top:200px;"> box </div>
16     </div>
17     <script type="text/javascript">
18     var o,   //捕获到的事件
19           X,  //box水平宽度
20           Y;  //box垂直高度
21     function getObject(obj,e){    //获取捕获到的对象
22         o = obj;
23         // document.all(IE)使用setCapture方法绑定;其余比如FF使用Window对象针对事件的捕捉
24         document.all?o.setCapture() : window.captureEvents(Event.MOUSEMOVE);
25         X = e.clientX - parseInt(o.style.left);   //获取宽度,
26         Y = e.clientY - parseInt(o.style.top);   //获取高度,
27     //    alert(e.clientX+"  -- " + o.style.left+" -- "+ X);
28     }
29     document.getElementById("box").onmousedown = function(e){
30         getObject(this,e||event);       //box捕获事件并处理  e-->FF  window.event-->IE
31     };
32     document.onmousemove = function(dis){    //鼠标移动事件处理
33         if(!o){    //如果未获取到相应对象则返回
34             return;
35         }
36         if(!dis){  //事件
37             dis = event ;
38         //    dis = arguments[0]||window.event;   //如果上面那句在FF下无法获取事件,听说可以通过 arguments[0]获取FF下的事件对象
39         }
40         o.style.left = dis.clientX - X +"px";     //设定box样式随鼠标移动而改变
41         o.style.top = dis.clientY - Y + "px";
42     };
43     document.onmouseup = function(){    //鼠标松开事件处理
44         if(!o){   //如果未获取到相应对象则返回
45             return;
46         }
47         // document.all(IE)使用releaseCapture解除绑定;其余比如FF使用window对象针对事件的捕捉
48         document.all?o.releaseCapture() : window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP)
49         o = ‘‘;   //还空对象
50     };
51     </script>
52 </body>
53 </html>
时间: 2024-12-29 11:57:29

简单的鼠标可拖动div 兼容IE/FF的相关文章

Javascript 简单实现鼠标拖动DIV

http://zhangbo-peipei-163-com.iteye.com/blog/1740078 比较精简的Javascript拖动效果函数代码 http://www.jb51.net/article/10578.htm <html> <head><title>拖动效果函数演示 by Longbill.cn</title> <style> body { font-size:12px; color:#333333; border : 0px

简单的鼠标拖动效果

使用js实现简单的鼠标拖动效果,但此部分代码有个小小的BUG,后期改进好我会写进来,但基本的效果已经实现,请大家参考. <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>鼠标移动</title> <style> #box{ width: 50px; height: 50px; position:

js实现可拖动Div

js实现可拖动Div 随着时代的变化,越来越感觉到js的重要性,js不仅可以做web页面(如Ext框架),还可以做一些web的特效,这些特效不仅兼容PC,而且兼容手机端,毕竟是基于浏览器的,和平台没关系.现在微软的windows8 系统的App都可以用js开发了,大家有时间可以去尝试一下. 现在切入正题,说一下js 实现可拖动Div.实现这个功能我们先说一下思路: 1.捕捉鼠标div的mousedown事件 2.捕捉 document的   mousemove事件 3.取消事件 然后我们看一下代

[可拖动DIV]刚开通博客顺便就写了点东西!

说说我自己的思路 首先需要一个初始div div { border: 1px #333 solid; width: 200px; height: 50px; } <div id="od">我是一个可拖动div</div> 然后就是鼠标事件,想象一下拖动这个过程需要用到哪些事件... 1.鼠标按钮按下事件mousedown 2.鼠标按钮松开事件mouseup 3.鼠标移动事件mousemove 第一步:给div添加鼠标按钮按下事件,这个事件需要完成以下事情 一.获

基于jquery的可拖动div

昨天给大家介绍了一款基于jquery ui漂亮的可拖动div实例,今天要给大家分享一款基于jquery的可拖动div.这款可拖动div只要引用jquery就可以,无需引用jquery ui.还实时记录的鼠标的坐标.一起看下效果图吧. 在线预览   源码下载 实现的代码. html代码: <span class="text noselect">DRAGGIN' WINDOWS<br /> <a href="http://www.w2bc.com&q

JS拖动DIV布局

方法一: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charse

jquery拖动DIV[转]

<!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 http-equiv="Conte

分享一个自定义打印套打方案(二),扩展Panel,以支持鼠标随意拖动

接上一章节,本篇主要介绍一种支持鼠标随意拖动Panel内部控件位置的方法.为了简单起见,这里我们不妨就暂称我们将要扩展的Panel容器名称为 MoveControlPanel,该容器至少需要实现以下功能 1. 识别当前鼠标位置,是否处于某个内部组件的边框位置,以让鼠标显示出对应的图标(拉伸,移动-) 2.移动鼠标以改变内部某个组件的大小及坐标, 3.保存容器内每个组件的当前坐标及大小. 为了便于描述当前光标状态,我们不妨定义一个枚举.姑且称其为 EMousePointPosition, 其至少应

只要把鼠标移上Div方框,方框就自动顺时针旋转

这是一个CSS3特效,IE下看不到效果.一个Div方框,在CSS3代码的作用下,只要把鼠标移上Div方框,方框就自动顺时针旋转.代码量不大,甚至有些简单,作为一个基础的CSS3实例,我想还是比较不错的,有一定参考价值. <!DOCTYPE html><html><head><meta charset="UTF-8"><title>CSS3旋转</title><style>.rotate {width: