随便找的一个,使用时直接调用gotoTop就行了,至于调速度之类的我没试,有兴趣的自己试试吧
注意:如果你想改变这个函数的名称千万不要忘了要同时改变第37行的那个gotoTop
1 /** 2 * JavaScript脚本实现回到页面顶部示例 3 * @param acceleration 速度 4 * @param stime 时间间隔 (毫秒) 5 **/ 6 function gotoTop(acceleration,stime) { 7 acceleration = acceleration || 0.1; 8 stime = stime || 10; 9 var x1 = 0; 10 var y1 = 0; 11 var x2 = 0; 12 var y2 = 0; 13 var x3 = 0; 14 var y3 = 0; 15 if (document.documentElement) { 16 x1 = document.documentElement.scrollLeft || 0; 17 y1 = document.documentElement.scrollTop || 0; 18 } 19 if (document.body) { 20 x2 = document.body.scrollLeft || 0; 21 y2 = document.body.scrollTop || 0; 22 } 23 var x3 = window.scrollX || 0; 24 var y3 = window.scrollY || 0; 25 26 // 滚动条到页面顶部的水平距离 27 var x = Math.max(x1, Math.max(x2, x3)); 28 // 滚动条到页面顶部的垂直距离 29 var y = Math.max(y1, Math.max(y2, y3)); 30 31 // 滚动距离 = 目前距离 / 速度, 因为距离原来越小, 速度是大于 1 的数, 所以滚动距离会越来越小 32 var speeding = 1 + acceleration; 33 window.scrollTo(Math.floor(x / speeding), Math.floor(y / speeding)); 34 35 // 如果距离不为零, 继续调用函数 36 if(x > 0 || y > 0) { 37 var run = "gotoTop(" + acceleration + ", " + stime + ")"; 38 window.setTimeout(run, stime); 39 } 40 }
时间: 2024-10-10 07:42:41