許多網頁在下方都會放置一個「回到頂部」按鈕,尤其是頁面底部沒有導航的網頁,這樣可以幫助訪客重新找到導航或重溫一遍廣告(想得真美)。隨著近幾年來 JavaScript 的應用日漸廣泛,滑動效果無所不在,於是我也跟風,將回傳頂部功能做成了滑動效果。後來為了更貼合物理特徵, 改造做成了減速的滑動效果。 先說一下原理吧,我們會取得滾動條到頁面頂部的距離,然後上移一定的距離;再獲取滾動條到頁面頂部的距離,上移一定的距離(比上一次小一點);以此類推... 複製程式碼 程式碼如下: <BR>/**<BR> * 回到頁上方<BR> * @param acceleration 加速<BR> * @param time 時間間隔 (毫秒)<BR> **/<BR>function goTop(acceleration, time) {<BR> acceleration = acceleration || 0.1;<BR> time = time || 16;<br><br> var x1 = 0;<BR> var y1 = 0;<BR> var x2 = 0;<BR> var y2 = 0;<BR> var x3 = 0;<BR> var y3 = 000; <br> if (document.documentElement) {<br> x1 = document.documentElement.scrollLeft || 0;<BR> y1 = document.documentElement.scrollTop ? ) {<BR> x2 = document.body.scrollLeft || 0;<BR> y2 = document.body.scrollTop || 0;<BR> }<BR> var x3 = || 0;<BR> }<BR> var x3 = ||window. var y3 = window.scrollY || 0;<BR><BR> // 滾動條到頁頂部的水平距離<br> var x = Math.max(x1, Math.max(x2, x3));<br> // 捲軸到頁面頂部的垂直距離<BR> var y = Math.max(y1, Math.max(y2, y3));<BR><BR> // 滾動距離= 目前距離/ 速度, 因為距離原來越小, 速度是大於1 的數, 所以滾動距離會越來越小<br> var speed = 1 acceleration;<br> window.scrollTo(Math.floor(x / speed), Math.floor(y / speed));<BR><BR> // 若距離不為零, 繼續呼叫迭代本函數<br> if(x > 0 || y > 0) {<br> var invokeFunction = "goTop(" acceleration ", " time ")";<BR> window.setTimeout(invokeFunction, time);<BR> }<BR>} <BR>document.docop. document.body.scrollTop, window.scrollY 其實都是一樣的,但它們只在某些瀏覽器中運作。至於那哪個在哪些瀏覽器起作用可以自己調試一下。 如何使用? 複製程式碼 程式碼如下: TOP