摘要:返回頂部這里初始狀態(tài)的返回頂部為不可見,通過判斷頁面滾動(dòng)高度切換顯示隱藏,的樣式可以自己設(shè)計(jì)。
返回頂部的按鈕大家并不陌生,針對(duì)長滾動(dòng)條的信息流頁面添加返回頂部的按鈕可以給用戶良好的體驗(yàn),而返回頂部的實(shí)現(xiàn)也是多種多樣,本文分享幾個(gè)案例并給出評(píng)價(jià)
作為引子講一個(gè)常用的案例,對(duì)與不知道的作為一個(gè)小彩蛋吧!對(duì)于微博與微信朋友圈的返回頂部可以雙擊最頂部的區(qū)域(包含時(shí)間,網(wǎng)絡(luò),電量)來返回頂部
大家見過哪些創(chuàng)意的返回頂部呢?歡迎留言交流,下面進(jìn)入正文
直接跳轉(zhuǎn)的方式對(duì)于追求極簡(jiǎn)的方式達(dá)到預(yù)期效果的人可能會(huì)喜歡這種方式,不托泥帶水也不用考慮兼容問題
國內(nèi)的大站如新浪主頁,淘寶網(wǎng),京東,百度新聞
不難發(fā)現(xiàn)此類的大站為了兼容性與瀏覽器渲染速度選擇了直接跳轉(zhuǎn)的方式,實(shí)現(xiàn)基本含兩種方式
命名錨點(diǎn)跳轉(zhuǎn)的方式用錨點(diǎn) #top(可變)返回到頂部預(yù)設(shè)的 id 為 top(可變)的元素,或者在頁面頂部的 a 標(biāo)簽 name 屬性值為 top(可變),新版本的瀏覽器(chrome等)默認(rèn)支持 #top 錨點(diǎn)返回頂部且不需要前面所提條件,但是前面條件的優(yōu)先級(jí)大于默認(rèn)跳轉(zhuǎn)。
上面說的有些繞口,下面逐句解釋,讀明白且理解的可以直接看下節(jié)
返回頂部頂部
上面代碼包含了所有的描述,簡(jiǎn)單易懂,下面說下優(yōu)先級(jí),這個(gè)是關(guān)鍵,避免無意中犯了錯(cuò)誤卻無從下手
注意: id > name > 默認(rèn)
不建議大家用默認(rèn)的方式,具體有兼容問題和優(yōu)先級(jí)低的問題,id 與 name 均可,但要注意命名沖突
scroll 函數(shù)跳轉(zhuǎn)window.scroll(x, y) 方法,x 是水平滾動(dòng)位置,y 是垂直滾動(dòng)位置,必須兩個(gè)參數(shù)都給進(jìn)去不然會(huì)報(bào)錯(cuò),大家可能發(fā)現(xiàn)有 window.scrollY,這里只改變垂直方向的滾動(dòng)為什么不能用,一個(gè)方面它返回的不是函數(shù)無法傳參,另一方面無法被賦值
返回頂部
這里方便展示,實(shí)際不建議在標(biāo)簽內(nèi)使用 js,可以調(diào)用一個(gè)方法,簡(jiǎn)單易懂。
setTimeout 模擬滾動(dòng)動(dòng)畫setTimeout() 方法遞歸調(diào)用,改變滾動(dòng)條距頂部位置
function backTop () { window.scrollBy(0, -100) scrolldelay = setTimeout("backTop()", 10) var sTop = document.documentElement.scrollTop + document.body.scrollTop if (sTop === 0) { clearTimeout(scrolldelay) } }
注意優(yōu)化網(wǎng)頁資源,使用不當(dāng)會(huì)非??D,可以通過調(diào)節(jié) setTimeout 的第二個(gè)參數(shù)來控制滾動(dòng)速度(回調(diào)時(shí)間單位 ms),下面解釋聲明sTop 變量的寫法
獲取scrollTop值,聲明了DTD的標(biāo)準(zhǔn)網(wǎng)頁取 document.documentElement.scrollTop,否則取 document.body.scrollTop 因?yàn)槎咧挥幸粋€(gè)會(huì)生效,另一個(gè)就恒為 0,所以取和值可以得到網(wǎng)頁的真正的 scrollTop 值
注:非標(biāo)準(zhǔn)版(webkit 內(nèi)核)采用的是 document.body.scrollTopwindow.requestAnimationFrame
window.requestAnimationFrame() 這個(gè)方法是用來在頁面重繪之前,通知瀏覽器調(diào)用一個(gè)指定的函數(shù),以滿足開發(fā)者操作動(dòng)畫的需求。這個(gè)方法接受一個(gè)函數(shù)為參,該函數(shù)會(huì)在重繪前調(diào)用。
完整的文檔看 MDN 和 JavaScript 標(biāo)準(zhǔn)參考教程(alpha),里面有詳細(xì)描述和兼容性詳情
看過文檔發(fā)現(xiàn) requestAnimationFrame 適合用于連續(xù)的動(dòng)畫,而我們的需求與連續(xù)動(dòng)畫關(guān)系大嗎?我們不妨一試。
const isWebkit = navigator.userAgent.toLowerCase().match(/webkit/([d.]+)/) const requestAnimationFrame = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || window.msRequestAnimationFrame function backTop () { let move = window.scrollY let span = move / 15 function step () { if (document.documentElement.scrollTop + document.body.scrollTop > 0) { if (isWebkit) { document.body.scrollTop -= 300 } else { document.documentElement.scrollTop -= 300 } requestAnimationFrame(step) } else { return } } requestAnimationFrame(step) }
上面代碼為什么定義 move 與 span 這里是方便計(jì)算速度,粘貼代碼運(yùn)行你會(huì)發(fā)現(xiàn)滾動(dòng)的距離越大速度就會(huì)越快,反而會(huì)越慢
這種用法本質(zhì)上可以使動(dòng)畫更加流暢,但是重點(diǎn)在于頁面優(yōu)化,requestAnimationFrame是在主線程上完成。這意味著,如果主線程非常繁忙,requestAnimationFrame的動(dòng)畫效果會(huì)大打折扣。
借助 jQuery目前的前端把焦點(diǎn)從 jQuery 移到了 MVVM 框架,不論如何當(dāng)初的 jQuery 對(duì)于 DOM 操作與低版本瀏覽器兼容貢獻(xiàn)巨大。如果你即考慮兼容性又想要流暢的動(dòng)畫可以繼續(xù)使用 jQuery。
function backTop (minHeight) { var backTopHtml = "返回頂部" $("#page").append(backTopHtml) $("#backTopBtn").click(function () { $("html, body").animate({scrollTop: 0}, 700) }).hover( function () { $(this).addClass("hover") }, function () { $(this).removeClass("hover") } ) minHeight ? minHeight = minHeight : minHeight = 600 $(window).scroll(function () { var s = $(window).scrollTop() if (s > minHeight) { $("#backTopBtn").fadeIn(100) } else { $("#backTopBtn").fadeOut(100) } }) } backTop()
這里初始狀態(tài)的返回頂部為不可見,通過判斷頁面滾動(dòng)高度切換顯示隱藏,hover 的樣式可以自己設(shè)計(jì)。
總結(jié)總結(jié)了幾種返回頂部的方式,orange 認(rèn)為滾動(dòng)或跳轉(zhuǎn)對(duì)用戶體驗(yàn)并沒有影響(影響用戶體驗(yàn)的是有沒有返回頂部的按鈕),既然選擇了返回頂部的按鈕那么性能一定是第一位的,一味追求滾動(dòng)動(dòng)畫導(dǎo)致頁面滾動(dòng)過程中卡頓進(jìn)而影響了整個(gè)網(wǎng)頁的用戶體驗(yàn),在這個(gè)細(xì)節(jié)上負(fù)面的例子太多不一一列舉。
總之本文的用意除了闡述各個(gè)方法的用法外還想提醒大家在前端開發(fā)中細(xì)節(jié)才是致命的,orange 也一直在踩坑,說到聰明的大廠為什么選用跳轉(zhuǎn),哈哈,先回去看看負(fù)面教材給我們的教訓(xùn)就知道了,技術(shù)點(diǎn)不在于滾動(dòng),而在于整個(gè)網(wǎng)頁的優(yōu)化,如果你的網(wǎng)站優(yōu)化的足夠好,那么拿滾動(dòng)來炫技沒人會(huì)反對(duì)。
文章出自 orange 的 個(gè)人博客 http://orangexc.xyz/
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/54392.html
摘要:返回頂部這里初始狀態(tài)的返回頂部為不可見,通過判斷頁面滾動(dòng)高度切換顯示隱藏,的樣式可以自己設(shè)計(jì)。 showImg(https://segmentfault.com/img/bVGDef?w=1390&h=540); 返回頂部的按鈕大家并不陌生,針對(duì)長滾動(dòng)條的信息流頁面添加返回頂部的按鈕可以給用戶良好的體驗(yàn),而返回頂部的實(shí)現(xiàn)也是多種多樣,本文分享幾個(gè)案例并給出評(píng)價(jià) 作為引子講一個(gè)常用的案例...
摘要:親測(cè)方法三會(huì)出現(xiàn)滾動(dòng)條。個(gè)人認(rèn)為方法一在靜態(tài)頁面中的使用比較合適 這里不提iframe,主要因?yàn)樵O(shè)計(jì)網(wǎng)頁相對(duì)比較困難,占用線程較多,速度慢,而且也不利于搜索引擎的對(duì)頭尾的收錄 方法一:通過load()函數(shù),分別引入公共頭部和底部文件; header.html 頂部頁面 頭部 ...
CSS盒模型以及與之相關(guān)的知識(shí)點(diǎn) 盒模型分為哪幾種 - 標(biāo)準(zhǔn)盒模型 - IE盒模型 兩者區(qū)別在于 width 和 height 計(jì)算方式上的不同: 標(biāo)準(zhǔn)盒模型 width = content width; IE核模型 width = content width + padding + border CSS 如何來設(shè)置這兩種模型 box-sizing: border-box box-siz...
CSS盒模型以及與之相關(guān)的知識(shí)點(diǎn) 盒模型分為哪幾種 - 標(biāo)準(zhǔn)盒模型 - IE盒模型 兩者區(qū)別在于 width 和 height 計(jì)算方式上的不同: 標(biāo)準(zhǔn)盒模型 width = content width; IE核模型 width = content width + padding + border CSS 如何來設(shè)置這兩種模型 box-sizing: border-box box-siz...
CSS盒模型以及與之相關(guān)的知識(shí)點(diǎn) 盒模型分為哪幾種 - 標(biāo)準(zhǔn)盒模型 - IE盒模型 兩者區(qū)別在于 width 和 height 計(jì)算方式上的不同: 標(biāo)準(zhǔn)盒模型 width = content width; IE核模型 width = content width + padding + border CSS 如何來設(shè)置這兩種模型 box-sizing: border-box box-siz...
閱讀 1878·2019-08-29 16:44
閱讀 2182·2019-08-29 16:30
閱讀 791·2019-08-29 15:12
閱讀 3534·2019-08-26 10:48
閱讀 2668·2019-08-23 18:33
閱讀 3788·2019-08-23 17:01
閱讀 1948·2019-08-23 15:54
閱讀 1311·2019-08-23 15:05