金山词霸即划即译设计随笔(二)
来源:互联网 发布:手机包厢点歌软件 编辑:程序博客网 时间:2024/06/05 06:31
下面按照上述步骤,一一细说。
用 javascript 获取当页面上鼠标(光标)位置在许多情况下都会用到,比如拖放,悬停提示(tooltip) 等等。当然,这里我们依然要面对浏览器的兼容问题,在不同的浏览器下,对这些相关的属性处理方式也不同,本文详细介绍了浏览器在处理这些属性时的差异和最终的解决方法。
因为在这篇文章中我们需要多次获取鼠标位置,所以我们设计了一个 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(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
};
}
上面的方法可以这样调用:
例如,我们为整个窗口注册onmousemove事件,定义了方法mouseMove(ev),用于监视鼠标移动的轨迹坐标:
function mouseMove(ev)...{
ev = ev || window.event;
var mousePos = mousePosition(ev);//调用上述mousePosition()方法
//下面,我们就可以这样获取鼠标位置了
var x=mousePosition.x;//获取鼠标所在位置的x轴坐标
var y=mousePosition.y;//获取鼠标所在位置的y轴坐标
}
上述代码只是举个例子而已,监视的是窗体的mousemove事件,而我们在设计此例时,却不能用这个。想一下,我们的查询是在用户用鼠标选择某一文本后执行的,因此,我们要用的事件无疑是onmouseup了,在用户选定文本以后才触发。具体代码如下:
function keyUp(ev)...{
ev = ev || window.event;
var mousePos = mousePosition(ev);
var x = mousePos.x;
var y= mousePos.y;
}
好了,到这里我们已经解决鼠标的定位了,为以后的结果显示层定位做好了准备。
MSN跟我交流
- 金山词霸即划即译设计随笔(二)
- 金山词霸即划即译设计随笔(一)
- 金山词霸即划即译设计随笔(三)
- 金山词霸即划即译设计随笔(四)
- 金山词霸即划即译设计随笔(五)
- 金山词霸即划即译设计随笔(六)
- 设计模式 随笔(二)
- 设计模式随笔(二):工厂方法(Factory Method)
- 《大话设计模式》精彩片段及个人随笔(二)
- 随笔(二)
- 随笔(二)
- 随笔(二)
- 随笔(二)
- C++随笔(二)
- iOS随笔(二)
- Kaldi随笔(二)
- 顺心随笔(二)
- 项目随笔(二)
- 用Visual C++实现远程线程嵌入木马技术
- assert
- fork()函数用法理解
- document.execCommand()说明收藏
- Delphi的编程语言Object Pascal(3)
- 金山词霸即划即译设计随笔(二)
- .net用户自定义控件创建
- 文件处理之四文件系统
- Java技术-J2EE开发日记-MyEclipse快捷键与插件大全
- 一些常用计算机管理命令
- 为ASP.NET封装的SQL数据库访问类
- 使用netcat命令网络同步复制系统
- 技术合同与实际需求不一致的困惑
- 利用文件控件来处理文件