JavaScript簡(jiǎn)單實(shí)現(xiàn)網(wǎng)頁回到頂部功能
更新時(shí)間:2013年11月12日 15:39:26 作者:
JavaScript簡(jiǎn)單實(shí)現(xiàn)網(wǎng)頁回到頂部功能,大家可以參考一下
很多網(wǎng)頁在下方都會(huì)放置一個(gè)“返回頂部”按鈕,尤其是頁面底部沒有導(dǎo)航的網(wǎng)頁,這樣可以幫助訪客重新找到導(dǎo)航或者重溫一遍廣告(想得真美)。隨著近幾年來 JavaScript 的應(yīng)用日漸廣泛,滑動(dòng)效果無處不在,于是我也跟跟風(fēng),將返回頂部功能做成了滑動(dòng)效果。后來為了更貼合物理特征, 改造做成了減速的滑動(dòng)效果。
首先說一下原理吧,我們會(huì)獲取滾動(dòng)條到頁面頂部的距離,然后上移一定的距離;再獲取滾動(dòng)條到頁面頂部的距離,上移一定的距離(比上一次小一點(diǎn));以此類推 ...
<script type="text/javascript">
/**
* 回到頁面頂部
* @param acceleration 加速度
* @param time 時(shí)間間隔 (毫秒)
**/
function goTop(acceleration, time) {
acceleration = acceleration || 0.1;
time = time || 16;
var x1 = 0;
var y1 = 0;
var x2 = 0;
var y2 = 0;
var x3 = 0;
var y3 = 0;
if (document.documentElement) {
x1 = document.documentElement.scrollLeft || 0;
y1 = document.documentElement.scrollTop || 0;
}
if (document.body) {
x2 = document.body.scrollLeft || 0;
y2 = document.body.scrollTop || 0;
}
var x3 = window.scrollX || 0;
var y3 = window.scrollY || 0;
// 滾動(dòng)條到頁面頂部的水平距離
var x = Math.max(x1, Math.max(x2, x3));
// 滾動(dòng)條到頁面頂部的垂直距離
var y = Math.max(y1, Math.max(y2, y3));
// 滾動(dòng)距離 = 目前距離 / 速度, 因?yàn)榫嚯x原來越小, 速度是大于 1 的數(shù), 所以滾動(dòng)距離會(huì)越來越小
var speed = 1 + acceleration;
window.scrollTo(Math.floor(x / speed), Math.floor(y / speed));
// 如果距離不為零, 繼續(xù)調(diào)用迭代本函數(shù)
if(x > 0 || y > 0) {
var invokeFunction = "goTop(" + acceleration + ", " + time + ")";
window.setTimeout(invokeFunction, time);
}
}
</script>
document.documentElement.scrollTop, document.body.scrollTop, window.scrollY 其實(shí)都是一樣的,但它們只在某些瀏覽器中起作用。至于那哪個(gè)在哪些瀏覽器起作用可以自己調(diào)試一下。
如何使用?
<a href="#" onclick="goTop();return false;">TOP</a>
首先說一下原理吧,我們會(huì)獲取滾動(dòng)條到頁面頂部的距離,然后上移一定的距離;再獲取滾動(dòng)條到頁面頂部的距離,上移一定的距離(比上一次小一點(diǎn));以此類推 ...
復(fù)制代碼 代碼如下:
<script type="text/javascript">
/**
* 回到頁面頂部
* @param acceleration 加速度
* @param time 時(shí)間間隔 (毫秒)
**/
function goTop(acceleration, time) {
acceleration = acceleration || 0.1;
time = time || 16;
var x1 = 0;
var y1 = 0;
var x2 = 0;
var y2 = 0;
var x3 = 0;
var y3 = 0;
if (document.documentElement) {
x1 = document.documentElement.scrollLeft || 0;
y1 = document.documentElement.scrollTop || 0;
}
if (document.body) {
x2 = document.body.scrollLeft || 0;
y2 = document.body.scrollTop || 0;
}
var x3 = window.scrollX || 0;
var y3 = window.scrollY || 0;
// 滾動(dòng)條到頁面頂部的水平距離
var x = Math.max(x1, Math.max(x2, x3));
// 滾動(dòng)條到頁面頂部的垂直距離
var y = Math.max(y1, Math.max(y2, y3));
// 滾動(dòng)距離 = 目前距離 / 速度, 因?yàn)榫嚯x原來越小, 速度是大于 1 的數(shù), 所以滾動(dòng)距離會(huì)越來越小
var speed = 1 + acceleration;
window.scrollTo(Math.floor(x / speed), Math.floor(y / speed));
// 如果距離不為零, 繼續(xù)調(diào)用迭代本函數(shù)
if(x > 0 || y > 0) {
var invokeFunction = "goTop(" + acceleration + ", " + time + ")";
window.setTimeout(invokeFunction, time);
}
}
</script>
document.documentElement.scrollTop, document.body.scrollTop, window.scrollY 其實(shí)都是一樣的,但它們只在某些瀏覽器中起作用。至于那哪個(gè)在哪些瀏覽器起作用可以自己調(diào)試一下。
如何使用?
復(fù)制代碼 代碼如下:
<a href="#" onclick="goTop();return false;">TOP</a>
您可能感興趣的文章:
- 頁面回到頂部的三種實(shí)現(xiàn)(錨標(biāo)記,js)
- js滾動(dòng)條回到頂部的代碼
- js隱藏與顯示回到頂部按鈕及window.onscroll事件應(yīng)用
- 用原生js做個(gè)簡(jiǎn)單的滑動(dòng)效果的回到頂部
- 原生js實(shí)現(xiàn)淘寶首頁點(diǎn)擊按鈕緩慢回到頂部效果
- 原生JS實(shí)現(xiàn)平滑回到頂部組件
- js+css實(shí)現(xiàn)回到頂部按鈕(back to top)
- 實(shí)現(xiàn)變速回到頂部的JavaScript代碼
- JS采用絕對(duì)定位實(shí)現(xiàn)回到頂部效果完整實(shí)例
- JS實(shí)現(xiàn)帶動(dòng)畫的回到頂部效果
相關(guān)文章
WEB泡泡堂2.0(圖形界面+電腦對(duì)玩)(javascript)
WEB泡泡堂2.0(圖形界面+電腦對(duì)玩)(javascript)2007-01-01JS中style.display和style.visibility的區(qū)別實(shí)例說明
下面的例子說明了這種區(qū)別:在這個(gè)例子中,divContent1和divContent2隱藏的時(shí)候用的是style.display=none,這時(shí)候,后面的div會(huì)向上移動(dòng),占據(jù)已經(jīng)隱藏的div的空間。divContent3和divContent4用的是style.visibility=hidden來隱藏,但是其隱藏后仍然占據(jù)原來的空間2013-03-03JavaScript實(shí)現(xiàn)判斷時(shí)間間隔是否連續(xù)為一天
這篇文章主要為大家詳細(xì)介紹了如何使用JavaScript實(shí)現(xiàn)判斷時(shí)間間隔是否連續(xù)為一天,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2024-01-01JS使用正則表達(dá)式過濾多個(gè)詞語并替換為相同長(zhǎng)度星號(hào)的方法
這篇文章主要介紹了JS使用正則表達(dá)式過濾多個(gè)詞語并替換為相同長(zhǎng)度星號(hào)的方法,涉及javascript字符串與正則替換操作相關(guān)技巧,需要的朋友可以參考下2016-08-08操作按鈕懸浮固定在微信小程序底部的實(shí)現(xiàn)代碼
在一些購物平臺(tái)經(jīng)常需要將商品加入購物車,像加入購物車按鈕、結(jié)算按鈕、收貨列表添加地址按鈕都是按鈕懸浮底部的,怎么實(shí)現(xiàn)這樣的功能呢?下面小編給大家?guī)砹瞬僮靼粹o懸浮固定在微信小程序底部的實(shí)現(xiàn)代碼,一起看看吧2019-08-08Javascript實(shí)現(xiàn)跨域后臺(tái)設(shè)置攔截的方法詳解
這篇文章主要給大家介紹了關(guān)于Javascript實(shí)現(xiàn)跨域后臺(tái)設(shè)置攔截的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08