鼠標跟隨,顧名思義,就是在鼠標移動的時候,有個動畫跟隨著鼠標一起移動。
要點一:
1
var oEvent = evt || window.event;
這個是為了兼容ie和ff而寫的,在ie下window.event表示event對象,而ff下,是給事件函數傳一個參數,這個參數就表示事件對象。
要點二:
1
document.onmousemove = function(evt)
鼠標跟隨是在鼠標移動時發生的事情。
要點三:
1
document.documentElement.scrollTop || document.body.scrollTop;
這是為了兼容chrome和其它浏覽器,滾動條距上邊滾動的距離,chrome用後邊那個,其它浏覽器用前面那個。
要點四:
1
oTop.style.top=oEvent.clientY+scrolltop+10+"px";
當鼠標移動時把鼠標的當前位置賦值給元素的位置值。
oEvent.clientY即為鼠標的當前Y坐標的位置,加scrolltop的距離是要在滾動到不是第一屏的時候,鼠標跟隨效果依然不改變而寫。
代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>無標題文檔</title>
<style>
body{margin:0; padding:0}
#to_top{
width:30px;
height:40px;
padding:20px;
font:14px/20px arial;
text-align:center;
background:#06c;
position:absolute;
cursor:pointer;
color:#fff
}
</style>
<script>
window.onload = function(){
var oTop = document.getElementById("to_top");
document.onmousemove = function(evt){
var oEvent = evt || window.event;
var scrollleft = document.documentElement.scrollLeft || document.body.scrollLeft;
var scrolltop = document.documentElement.scrollTop || document.body.scrollTop;
oTop.style.left = oEvent.clientX + scrollleft +10 +"px";
oTop.style.top = oEvent.clientY + scrolltop + 10 + "px";
}
}
</script>
</head>
<body style="height:1000px;">
<a href="#">文字</a>
<div id="to_top">鼠標跟隨</div>
</body>
</html>