js獲取鼠標(biāo)位置實(shí)例詳解
本文實(shí)例講述了js獲取鼠標(biāo)位置的方法。分享給大家供大家參考,具體如下:
用 javascript 獲取當(dāng)前頁(yè)面上鼠標(biāo)(光標(biāo))位置在許多情況下都會(huì)用到,比如拖放,懸停提示(tooltip) 等等。當(dāng)然,這里我們依然要面對(duì)瀏覽器的兼容問(wèn)題,在不同的瀏覽器下,對(duì)這些相關(guān)的屬性處理方式也不同,這里詳細(xì)介紹了瀏覽器在處理這些屬性時(shí)的差異和最終的解決方法。
Javascript代碼如下:
<script type="text/javascript">
// 說(shuō)明:獲取鼠標(biāo)位置
// 整理:http://www.codebit.cn
// 來(lái)源: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);
}
關(guān)于代碼的詳細(xì)說(shuō)明如下:
我們首先要聲明一個(gè) evnet 對(duì)象,無(wú)論移動(dòng)、點(diǎn)擊、按鍵等,都會(huì)激活一個(gè) evnet ,在 Internet Explorer 里, event 是全局變量,會(huì)被存儲(chǔ)在 window.event 里. 在 firefox 或者其他瀏覽器,event 會(huì)被相應(yīng)的函數(shù)獲?。?dāng)我們將mouseMove函數(shù)賦值于document.onmousemove,mouseMove 會(huì)獲取鼠標(biāo)移動(dòng)事件。
為了讓 ev 在所有瀏覽器下獲取了 event 事件,在Firefox下"||window.event"將不起作用,因?yàn)閑v已經(jīng)有了賦值。在 MSIE 中 ev 為空,所以得到 window.event 。
因?yàn)樵谶@篇文章中我們需要多次獲取鼠標(biāo)位置,所以我們?cè)O(shè)計(jì)了一個(gè) mousePosition 函數(shù),它包含一個(gè)參數(shù) : event 。
因?yàn)槲覀円?MSIE 和其他瀏覽器下運(yùn)行,F(xiàn)irefox 和其他瀏覽器用 event.pageX 和 event.pageY 來(lái)表示鼠標(biāo)相對(duì)于文檔的位置,如果你有一個(gè) 500*500 的窗口并且你的鼠標(biāo)在絕對(duì)中間,那么 pageX 和 pageY 的值都是 250,如果你向下滾動(dòng) 500, 那么 pageY 將變成 750。
MSIE 正好相反,它使用 event.clientX 和 event.clientY 表示鼠標(biāo)相當(dāng)于窗口的位置,而不是文檔。在同樣的例子中,如果你向下滾動(dòng)500,clientY 依然是 250,因此,我們需要添加 scrollLeft 和 scrollTop 這兩個(gè)相對(duì)于文檔的屬性。最后,MSIE 中文檔并不是從 0,0 開(kāi)始,而是通常有一個(gè)小的邊框(通常是 2 象素),邊框的大小定義在 document.body.clientLeft 和 clientTop 中,我們也把這些加進(jìn)去。
完成代碼:
<script type="text/javascript">
// 說(shuō)明:獲取鼠標(biāo)位置
// 整理:http://www.codebit.cn
// 來(lái)源: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
};
}
document.onmousemove = mouseMove;
function mouseMove(ev){
ev = ev || window.event;
var mousePos = mousePosition(ev);
document.getElementByIdx('mouseXPosition').value = mousePos.x;
document.getElementByIdx('mouseYPosition').value = mousePos.y;
}
</script>
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- js與jquery中獲取當(dāng)前鼠標(biāo)的x、y坐標(biāo)位置的代碼
- 使用JS獲取當(dāng)前地理位置方法匯總
- js獲取元素在瀏覽器中的絕對(duì)位置
- js實(shí)現(xiàn)滾動(dòng)條滾動(dòng)到某個(gè)位置便自動(dòng)定位某個(gè)tr
- js獲取元素相對(duì)窗口位置的實(shí)現(xiàn)代碼
- JS中獲取 DOM 元素的絕對(duì)位置實(shí)例詳解
- JS控制彈出新頁(yè)面窗口位置和大小的方法
- JS獲取當(dāng)前地理位置的方法
- js實(shí)現(xiàn)獲取鼠標(biāo)當(dāng)前的位置
- 一篇文章讓你徹底搞懂js中的位置計(jì)算
相關(guān)文章
Javascript實(shí)現(xiàn)的簡(jiǎn)單右鍵菜單類
這篇文章主要介紹了Javascript實(shí)現(xiàn)的簡(jiǎn)單右鍵菜單類,通過(guò)JavaScript自定義類實(shí)現(xiàn)右鍵菜單功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
跟我學(xué)習(xí)javascript的嚴(yán)格模式
跟我學(xué)習(xí)javascript的嚴(yán)格模式,對(duì)javascript嚴(yán)格模式進(jìn)行概述,進(jìn)入嚴(yán)格模式的方法,以及如何調(diào)用和相關(guān)語(yǔ)法,感興趣的小伙伴們可以參考一下2015-11-11
js實(shí)現(xiàn)二級(jí)菜單點(diǎn)擊顯示當(dāng)前內(nèi)容效果
這篇文章主要介紹了js實(shí)現(xiàn)二級(jí)菜單點(diǎn)擊顯示當(dāng)前內(nèi)容效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04
判斷是否安裝flash player及當(dāng)前版本的JS代碼
本文為大家講述下如何使用jsJS判斷是否安裝flash player及版本,下面的處理代碼或許對(duì)大家有所幫助,感興趣的朋友可以參考下,希望對(duì)大家有所幫助2013-08-08
uniapp使用webview嵌入vue頁(yè)面及通信實(shí)現(xiàn)方式
項(xiàng)目中有需要嵌入其他H5的頁(yè)面的業(yè)務(wù)需求,這篇文章主要給大家介紹了關(guān)于uniapp使用webview嵌入vue頁(yè)面及通信實(shí)現(xiàn)方式的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01

