JavaScript 設(shè)計鼠標跟隨
■知識點
當(dāng)事件發(fā)生時,利用事件對象的坐標屬性可以獲取鼠標指針的位置,說明如表所示。
屬 性 | 說 明 | 兼容性 |
clientX | 以瀏覽器窗口左上頂角為原點,定位x軸坐標 | 所有瀏覽器,不兼容Safari |
clientY | 以瀏覽器窗口左上頂角為原點,定位y軸坐標 | 所有瀏覽器,不兼容Safari |
offsetX | 以當(dāng)前事件的目標對象左上頂角為原點,定位x軸坐標 | 所有瀏覽器,不兼容Mozilla |
offsetY | 以當(dāng)前事件的Hi標對象左上頂角為原點,定位y軸坐標 | 所有瀏覽器,不兼容Mozilla |
pagcX | 以document對象(即文檔窗口)左上頂角為原點,定位x軸坐標 | 所有瀏覽器,不兼容IE |
pageY | 以document對象(即文檔窗口)左上頂角為原點,定位y軸坐標 | 所有瀏覽器,不兼容IE |
screenX | 計算機屏幕左上頂角為原點,定位x軸坐標 | 所有瀏覽器 |
screenY | 計算機屏幕左上頂角為原點,定位y軸坐標 | 所有瀏覽器 |
layerX | 最近的絕對定位的父元素(如果沒有,則為document對象)左上頂 角為原點,定位x軸坐標 | Mozilla 和 Safari |
layerY | 最近的絕對定位的父元素(如果沒有,則為document對象)左上頂 角為原點,定位y軸坐標 | Mozilla 和 Safari |
■實例設(shè)計
設(shè)計一個函數(shù),根據(jù)事件對象獲取鼠標指針的坐標值,設(shè)置該對象為絕對定位,絕對定位的值為鼠標指針當(dāng)前的坐標值。定義形參為:對象引用指針、相對鼠標指針的偏移距離以及事件對象。
var pos = function(o, x, y,event){ //鼠標指針定位賦值函數(shù)
var posX = 0, posY = 0; //臨時變量值
var e = event || window.event; //標準化事件對象
if(e.pageX || e.pageY){ //獲取鼠標指針的當(dāng)前坐標值
posX = e.pageX;
posY = e.pageY;
}
else if(e.clientX |丨 e.clientY){
posX = e.clientX + document.documentElement.scrollLeft + document.body.scrollLeft;
posY = e.clientY + document.documentElement.scrollTop + document.body.scrollTop;
}
o.style.position = "absolute"; //定義當(dāng)前對象為絕對定位
o.style.top = (posY + y) + "px"; //用鼠標指針的y軸坐標和傳入偏移值設(shè)置對象y軸坐標
o.style.left = (posX + x) + "px"; //用鼠標指針的x軸坐標和傳入偏移值設(shè)置對象x軸坐標
}
下面為document對象注冊鼠標移動事件處理函數(shù),并傳入鼠標定位封裝函數(shù),傳入的對象為<div>元素,設(shè)置其位置向鼠標指針右下方偏移(10,20)的距離??紤]到DOM事件模型通過參數(shù)形式傳遞事件對象,所以不要忘記在調(diào)用函數(shù)中還要傳遞事件對象。
<div id="divl">鼠標跟隨</div>
<script>
var divl = document.getElementByld("divl");
document.onmousemove = function(event){
pos(divl, 10, 20,event);
}
</script>
點擊加載更多評論>>