国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

網(wǎng)頁中返回頂部代碼(多種方法)另附注釋說明

2019-11-20 22:46:28
字體:
供稿:網(wǎng)友

下面就說下簡單的返回頂部效果的代碼實(shí)現(xiàn),附注釋說明。
1. 最簡單的靜態(tài)返回頂部,點(diǎn)擊直接跳轉(zhuǎn)頁面頂部,常見于固定放置在頁面底部返回頂部功能
方法一:用命名錨點(diǎn)擊返回到頂部預(yù)設(shè)的id為top的元素
復(fù)制代碼 代碼如下:

<a href="#top" target="_self">返回頂部</a>

方法二:操作scrooll函數(shù)用來控制滾動條的位置(第一個參數(shù)是水平位置,第二個參數(shù)是垂直位置)
復(fù)制代碼 代碼如下:

<a href="javascript:scroll(0,0)">返回頂部</a>

缺點(diǎn):返回效果是立即的,不符合一般瀏覽頁面的滾動感覺;
靜態(tài)固定于頁面底部,用戶不一定看得到。

2. 簡單的靜態(tài)返回頂部,用js模擬滾動效果上滑至頂部
復(fù)制代碼 代碼如下:

function pageScroll(){
//把內(nèi)容滾動指定的像素數(shù)(第一個參數(shù)是向右滾動的像素數(shù),第二個參數(shù)是向下滾動的像素數(shù))
window.scrollBy(0,-100);
//延時遞歸調(diào)用,模擬滾動向上效果
scrolldelay = setTimeout('pageScroll()',100);
//獲取scrollTop值,聲明了DTD的標(biāo)準(zhǔn)網(wǎng)頁取document.documentElement.scrollTop,否則取document.body.scrollTop;因?yàn)槎咧挥幸粋€會生效,另一個就恒為0,所以取和值可以得到網(wǎng)頁的真正的scrollTop值
var sTop=document.documentElement.scrollTop+document.body.scrollTop;
//判斷當(dāng)頁面到達(dá)頂部,取消延時代碼(否則頁面滾動到頂部會無法再向下正常瀏覽頁面)
if(sTop==0) clearTimeout(scrolldelay);
}

復(fù)制代碼 代碼如下:

<a onclick="pageScroll()">返回頂部</a>

缺點(diǎn):滾動效果不平滑,且在頁面很長時點(diǎn)擊返回頂部,未向上到達(dá)頁面頂部無法再正常瀏覽頁面;
同上依舊是靜態(tài)固定于頁面底部,不一定能曝光在用戶面前。

3. 動態(tài)按需加載返回頂部,css側(cè)邊屏幕絕對定位,結(jié)合簡單jQuery動畫實(shí)現(xiàn)更好體驗(yàn)
復(fù)制代碼 代碼如下:

function gotoTop(min_height){
//預(yù)定義返回頂部的html代碼,它的css樣式默認(rèn)為不顯示
var gotoTop_html = '<div id="gotoTop">返回頂部</div>';
//將返回頂部的html代碼插入頁面上id為page的元素的末尾
$("#page").append(gotoTop_html);
$("#gotoTop").click(//定義返回頂部點(diǎn)擊向上滾動的動畫
function(){$('html,body').animate({scrollTop:0},700);
}).hover(//為返回頂部增加鼠標(biāo)進(jìn)入的反饋效果,用添加刪除css類實(shí)現(xiàn)
function(){$(this).addClass("hover");},
function(){$(this).removeClass("hover");
});
//獲取頁面的最小高度,無傳入值則默認(rèn)為600像素
min_height ? min_height = min_height : min_height = 600;
//為窗口的scroll事件綁定處理函數(shù)
$(window).scroll(function(){
//獲取窗口的滾動條的垂直位置
var s = $(window).scrollTop();
//當(dāng)窗口的滾動條的垂直位置大于頁面的最小高度時,讓返回頂部元素漸現(xiàn),否則漸隱
if( s > min_height){
$("#gotoTop").fadeIn(100);
}else{
$("#gotoTop").fadeOut(200);
};
});
};
gotoTop();

css樣式代碼:
復(fù)制代碼 代碼如下:

/*默認(rèn)樣式,主要是position:fixed實(shí)現(xiàn)屏幕絕對定位*/
#gotoTop{display:none;position:fixed;top:75%;left:50%;cursor:pointer;margin-top:-50px;margin-left:520px;padding:9px 4px;width:20px;text-align:center;border:1px solid #e0e0e0;background:#fff;}
/*用CSS表達(dá)式(expression)來實(shí)現(xiàn)ie6下position:fixed效果*/
#gotoTop{_position:absolute;_top:expression(documentElement.scrollTop + documentElement.clientHeight * 3/4 + "px")}
/*鼠標(biāo)進(jìn)入的反饋效果*/
#gotoTop.hover{background:#5CB542;color:#fff;text-decoration:none;}

這種方法判斷頁面高度按需將“返回頂部”展示給用戶,用css樣式實(shí)現(xiàn)了屏幕絕對定位,借助jQuery實(shí)現(xiàn)了更好用平滑的滾動效果。進(jìn)一步考慮如果用戶設(shè)置了瀏覽器禁用js,那么我們可以將第三方案結(jié)合第一方案方法一,禁用js后第三方案將不被用戶所見,未禁用的話我們在js代碼中再加上一句隱藏第一方案。

總之,長頁面還是要盡量避免的,不可避免的情況下,加上“返回頂部”功能可能會帶給用戶相對好一點(diǎn)的體驗(yàn)。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 北宁市| 普格县| 湾仔区| 大厂| 普陀区| 台中县| 塔城市| 钟祥市| 金寨县| 三门峡市| 易门县| 墨竹工卡县| 邻水| 犍为县| 团风县| 富蕴县| 玉溪市| 姜堰市| 宁河县| 揭阳市| 油尖旺区| 合山市| 克拉玛依市| 民权县| 礼泉县| 鄂温| 泸州市| 梓潼县| 福建省| 青浦区| 措美县| 沽源县| 乐都县| 华蓥市| 邢台县| 义马市| 盐津县| 临高县| 呈贡县| 营山县| 淮阳县|