詳解原生JS回到頂部
第一次知道可以用超鏈接(錨點(diǎn))實(shí)現(xiàn)回到頂部的時(shí)候我是很震驚的,想著原來可以這么簡單??!但是作為一個(gè)正在學(xué)習(xí)JS的小白,不能就這么輕易止步,所以查資料自己整了一個(gè)JS的回到頂部。
HTML代碼:
<div class="container"> <p>你好哇</p> ... </div> <div id="top">回到頂部</div>
CSS代碼:
.container{
border: 1px solid black;
}
#top{
position: fixed;
padding: 10px;
width: 20px;
border: 1px solid black;
box-shadow: 0 0 2px #333;
right: 20px;
bottom: 20px;
}
#top:hover{
cursor: pointer;
}
JS代碼:
//創(chuàng)建變量
var scroll_Top = document.getElementById('top');
//用最常用的scrollTop屬性實(shí)現(xiàn)
var timer = null;
function scrollTop(){
// 取消一個(gè)通過調(diào)用requestAnimationFrame()方法添加到計(jì)劃中的動(dòng)畫幀請求.
cancelAnimationFrame(timer);
/* requestAnimationFrame 會(huì)把每一幀中的所有DOM操作集中起來,
在一次重繪或回流中就完成,并且重繪或回流的時(shí)間間隔緊緊跟隨瀏覽器的刷新頻率
一般來說,這個(gè)頻率為每秒60幀。 */
timer = requestAnimationFrame(function sTop(){
var top = document.body.scrollTop || document.documentElement.scrollTop;
if(top > 0){
//使用定時(shí)器,將scrollTop的值每次減少20(自行設(shè)置),直到減少到0,則滾動(dòng)完畢
document.body.scrollTop = document.documentElement.scrollTop = top - 20;
timer = requestAnimationFrame(sTop);
}else{
cancelAnimationFrame(timer);
}
});
}
scroll_Top.addEventListener('click', scrollTop, false);
效果手動(dòng)截圖:


以上所述是小編給大家介紹的JS回到頂部詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
JavaScript學(xué)習(xí)筆記(十七)js 優(yōu)化
在JavaScript中,我們可以使用for(;;),while(),for(in)三種循環(huán),事實(shí)上,這三種循環(huán)中for(in)的效率極差,因?yàn)樗枰樵兩⒘墟I,只要可以就應(yīng)該盡量少用。2010-02-02
JavaScript與DOM組合動(dòng)態(tài)創(chuàng)建表格實(shí)例
這篇文章簡單介紹了DOM 1.0一些基本而強(qiáng)大的方法以及如何在JavaScript中使用它們;你可以學(xué)到如何動(dòng)態(tài)地創(chuàng)建、獲取、控制和刪除HTML元素2012-12-12
JavaScript操作HTML DOM節(jié)點(diǎn)的基礎(chǔ)教程
這篇文章主要介紹了JavaScript操作HTML DOM節(jié)點(diǎn)的基礎(chǔ)入門教程,包括對節(jié)點(diǎn)的創(chuàng)建修改刪除等操作,還特別提到了其中appendChild()與insertBefore()插入節(jié)點(diǎn)時(shí)需注意的問題,需要的朋友可以參考下2016-03-03
在javascript中關(guān)于節(jié)點(diǎn)內(nèi)容加強(qiáng)
本篇文章,小編為大家介紹,關(guān)于在javascript中關(guān)于節(jié)點(diǎn)內(nèi)容加強(qiáng)的問題2013-04-04

