位置:首頁 > 軟件操作教程 > 編程開發(fā) > JavaScript > 問題詳情

JavaScript 設計鼠標跟隨

提問人:劉團圓發(fā)布時間:2020-11-27

■知識點

當事件發(fā)生時,利用事件對象的坐標屬性可以獲取鼠標指針的位置,說明如表所示。

兼容性

clientX

以瀏覽器窗口左上頂角為原點,定位x軸坐標

所有瀏覽器,不兼容Safari

clientY

以瀏覽器窗口左上頂角為原點,定位y軸坐標

所有瀏覽器,不兼容Safari

offsetX

以當前事件的目標對象左上頂角為原點,定位x軸坐標

所有瀏覽器,不兼容Mozilla

offsetY

以當前事件的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ù),根據(jù)事件對象獲取鼠標指針的坐標值,設置該對象為絕對定位,絕對定位的值為鼠標指針當前的坐標值。定義形參為:對象引用指針、相對鼠標指針的偏移距離以及事件對象。

var pos = function(o, x, y,event){        //鼠標指針定位賦值函數(shù)

    var posX = 0, posY = 0;               //臨時變量值 

    var e = event || window.event;        //標準化事件對象

    if(e.pageX || e.pageY){               //獲取鼠標指針的當前坐標值

        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";    //定義當前對象為絕對定位

    o.style.top = (posY + y) + "px";  //用鼠標指針的y軸坐標和傳入偏移值設置對象y軸坐標 

    o.style.left = (posX + x) + "px"; //用鼠標指針的x軸坐標和傳入偏移值設置對象x軸坐標

}

    下面為document對象注冊鼠標移動事件處理函數(shù),并傳入鼠標定位封裝函數(shù),傳入的對象為<div>元素,設置其位置向鼠標指針右下方偏移(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>


繼續(xù)查找其他問題的答案?

相關(guān)視頻回答
回復(0)
返回頂部