博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS鼠标捕获DIV内选中的坐标和宽高
阅读量:4361 次
发布时间:2019-06-07

本文共 2852 字,大约阅读时间需要 9 分钟。

用 javascript 获取当页面上鼠标(光标)位置在许多情况下都会用到,比如拖放,悬停提示(tooltip) 等等。当然,这里我们依然要面对浏览器的兼容问题,在不同的浏览器下,对这些相关的属性处理方式也不同,本文详细介绍了浏览器在处理这些属性时的差异和最终的解决方法。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<script type=
"text/javascript"
>
  
// 说明:获取鼠标位置
// 整理:http://www.codebit.cn
// 来源:http://www.webreference.com
  
function
mousePosition(ev){
    
if
(ev.pageX || ev.pageY){
        
return
{x:ev.pageX, y:ev.pageY};
    
}
    
return
{
        
x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,
        
y:ev.clientY + document.body.scrollTop  - document.body.clientTop
    
};
}
  
</script>

上面的代码我们在  中已经介绍过了,由于这个需求我们经常用到,所以我们将这段代码独立成一篇文章,供新手查询。

使用方式:

document.onmousemove = mouseMove; function mouseMove(ev){	ev = ev || window.event;	var mousePos = mousePosition(ev);}

关于代码的详细说明,原文中已经介绍,现转到此处:

我们首先要声明一个 evnet 对象,无论移动、点击、按键等,都会激活一个 evnet ,在 Internet Explorer 里, event 是全局变量,会被存储在 window.event 里. 在 firefox 或者其他浏览器,event 会被相应的函数获取.当我们将mouseMove函数赋值于document.onmousemove,mouseMove 会获取鼠标移动事件。

为了让 ev 在所有浏览器下获取了 event 事件,在Firefox下"||window.event"将不起作用,因为ev已经有了赋值。在 MSIE 中 ev 为空,所以得到 window.event 。

因为在这篇文章中我们需要多次获取鼠标位置,所以我们设计了一个 mousePosition 函数,它包含一个参数 : event 。

因为我们要在 MSIE 和其他浏览器下运行,Firefox 和其他浏览器用 event.pageX 和 event.pageY 来表示鼠标相对于文档的位置,如果你有一个 500*500 的窗口并且你的鼠标在绝对中间,那么 pageX 和 pageY 的值都是 250,如果你向下滚动 500, 那么 pageY 将变成 750。

MSIE 正好相反,它使用 event.clientX 和 event.clientY 表示鼠标相当于窗口的位置,而不是文档。在同样的例子中,如果你向下滚动500,clientY 依然是 250,因此,我们需要添加 scrollLeft 和 scrollTop 这两个相对于文档的属性。最后,MSIE 中文档并不是从 0,0 开始,而是通常有一个小的边框(通常是 2 象素),边框的大小定义在 document.body.clientLeft 和 clientTop 中,我们也把这些加进去。

很幸运,我们现在已经用 mousePosition 函数解决了坐标问题,不需为此费心了。

 

最近做一个项目,每组数据的条目比较多,在浏览页面,不能把所有的信息都显示出来,就想做一个层,让它默认隐藏,在鼠标划过条目标题的时候,显示更多的内容,鼠标移走后,隐藏。

这就用到了javascript的onmouseover,和onmouseout事件。

这两个函数如下:

1:  //鼠标悬停,显示层
2:  function  show(ev,id){
3:      var tag='divshowtext'+id;
4:      var divshow=document.getElementById(tag);
5:      var mp = getMouseLocation();
6:      var x=mp.x;
7:      var y=mp.y;
8:      x=x+20;//曾显示位置相对于鼠标当前位置的偏移量
9:      y=y+20;//曾显示位置相对于鼠标当前位置的偏移量
10:      divshow.style.left=x+"px";
11:      divshow.style.top=y+"px";
12:      divshow.style.visibility= "visible";
13:  };
14:  //鼠标滑出,隐藏层
15:  function  hide(id){
16:      var tag='divshowtext'+id;
17:      var divshow=document.getElementById(tag);
18:      divshow.style.visibility= "hidden";
19:  };

其中第4行的getMouseLocation()函数,见上一篇

在显示条目的主循环中,调用:

<a href="<?php echo $url;?>" target="_self"  οnmοuseοver="show(event,<?php echo $id; ?>)" οnmοuseοut="hide(<?php echo $id; ?>)">

同时在条目显示主循环里,还要显示相对应的<div>层:

发布于:
……

层的CSS样式里,主要的就是要设置为默认隐藏,定位“absolute”,其他的根据需要设置:

.divshow_text

{

    background-color:#FFC;

    font-size:12px;
    visibility:hidden;
    z-index:9999;
    position:absolute;
    padding:5px;
    text-align:left;
    word-wrap:break-word;
    border: 1px solid #FCF;
}

转载于:https://www.cnblogs.com/duanxz/archive/2013/02/28/2936863.html

你可能感兴趣的文章
Windows系统下解决“telnet不是外部或内部命令”的问题
查看>>
C语言代码优化(转)
查看>>
python实现mapreduce(1)——模拟MR过程
查看>>
hyper-v中提示”未在远程桌面会话中捕获到鼠标“
查看>>
APACHE2 服务器配置 (一)
查看>>
JAVA JVM 流程一
查看>>
35displayinline-block的上下对齐方式
查看>>
Jquery的普通事件和on的委托事件
查看>>
IE低版本兼容的感悟
查看>>
JAVA获取当前日期是星期几
查看>>
c++ 转换unicode字符串为js \u格式
查看>>
python学习笔记——多线程编程
查看>>
zipline目录结构
查看>>
1. Scala概述
查看>>
Ubuntu下安装mysql与mysql workbench
查看>>
HDOJ1251解题报告【字典树】
查看>>
java 字符串zlib压缩/解压
查看>>
httpclient新旧版本分割点4.3
查看>>
实现小数据量和海量数据的通用分页显示存储过程
查看>>
JPEG文件结构
查看>>