JS實(shí)現(xiàn)刷新網(wǎng)頁(yè)后之前瀏覽位置保持不變示例詳解
正文
在京東上瀏覽的時(shí)候,發(fā)現(xiàn)了一個(gè)比較人性化的小功能,瀏覽商品,瀏覽到一半的時(shí)候,如下圖所示:
我重新加載網(wǎng)頁(yè),刷新之后,滾動(dòng)條依然定位在我剛剛瀏覽的位置,這個(gè)小功能感覺(jué)還不錯(cuò),挺方便的。
具體是怎么實(shí)現(xiàn)的呢,去網(wǎng)上大概查了一下。
這個(gè)是使用滾動(dòng)條屬性scrollTop來(lái)實(shí)現(xiàn)的。
基本實(shí)現(xiàn)流程:滾動(dòng)條移動(dòng)的時(shí)候,將滾動(dòng)條實(shí)時(shí)的位置存入Cookie或者localstorage中,但是一些老舊的瀏覽器版本對(duì)localstorage支持不是特別友好。
如果你想使用localstorage來(lái)實(shí)現(xiàn),請(qǐng)參照《VUE自學(xué)筆記之使用localstorage和sessionstorage實(shí)現(xiàn)登錄》
我這里使用的是cookie來(lái)存儲(chǔ)。
這里有兩個(gè)方法
方法一:這個(gè)比較集中
/** * @name: 控制 瀏覽器滾動(dòng)條 * @author: camellia * @email: guanchao_gc@qq.com * @date: 2022-01-10 */ window.onscroll = function() { var scrollPos; if (typeof window.pageYOffset != 'undefined') { scrollPos = window.pageYOffset; } else if (typeof document.body != 'undefined') { scrollPos = document.body.scrollTop; } document.cookie = "scrollTop=" + scrollPos; } window.onload = function (){ if (document.cookie.match(/scrollTop=([^;]+)(;|$)/) != null) { var arr = document.cookie.match(/scrollTop=([^;]+)(;|$)/); document.body.scrollTop = parseInt(arr[1]); } }
方法二:cookie存取各封裝成函數(shù)
這個(gè)將cookie的存取各封裝成了一個(gè)函數(shù),調(diào)用更靈活。
window.onscroll = function() { var scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop; SetCookie("a", scrollTop); } window.onload = function () { document.body.scrollTop = GetCookie("a");//頁(yè)面加載時(shí)設(shè)置scrolltop高度 } /** * @name: 設(shè)置cookie * @author: camellia * @email: guanchao_gc@qq.com * @date: 2022-01-10 */ function SetCookie(sName, sValue) { document.cookie = sName + "=" + escape(sValue) + "; "; } /** * @name: 讀取cookie * @author: camellia * @email: guanchao_gc@qq.com * @date: 2022-01-10 */ function GetCookie(sName) { var aCookie = document.cookie.split("; "); for (var i = 0; i < aCookie.length; i++) { var aCrumb = aCookie[i].split("="); if (sName == aCrumb[0]) { return unescape(aCrumb[1]); } } return 0; }
其實(shí)這個(gè)就是一個(gè)對(duì)cookie存儲(chǔ)和取值以及scrollTop賦值的一個(gè)過(guò)程,不是很難。
上邊的兩段代碼,一般情況下,只要放到你的項(xiàng)目里邊就能好用。
如果不好用,請(qǐng)重新檢查一下,你的項(xiàng)目中是否還有別的地方對(duì)scrollTop賦值。
以上就是JS實(shí)現(xiàn)刷新網(wǎng)頁(yè)后之前瀏覽位置保持不變示例詳解的詳細(xì)內(nèi)容,更多關(guān)于JS刷新網(wǎng)頁(yè)瀏覽位置保持的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序 圖片加載(本地,網(wǎng)路)實(shí)例詳解
這篇文章主要介紹了微信小程序 圖片加載(本地,網(wǎng)路)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03uniApp學(xué)習(xí)之熱門搜索,搜索數(shù)據(jù)頁(yè)面緩存實(shí)例
這篇文章主要介紹了uniApp學(xué)習(xí)之熱門搜索,搜索數(shù)據(jù)頁(yè)面緩存實(shí)例,需要的朋友可以參考下2023-10-10JS前端錯(cuò)誤監(jiān)控捕獲以及上報(bào)方法詳解
這篇文章主要為大家介紹了前端錯(cuò)誤監(jiān)控捕獲以及上報(bào)方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01微信小程序 實(shí)現(xiàn)點(diǎn)擊添加移除class
這篇文章主要介紹了 微信小程序 實(shí)現(xiàn)點(diǎn)擊添加移除class的相關(guān)資料,需要的朋友可以參考下2017-06-06