JS實現(xiàn)刷新網(wǎng)頁后之前瀏覽位置保持不變示例詳解
正文
在京東上瀏覽的時候,發(fā)現(xiàn)了一個比較人性化的小功能,瀏覽商品,瀏覽到一半的時候,如下圖所示:
我重新加載網(wǎng)頁,刷新之后,滾動條依然定位在我剛剛瀏覽的位置,這個小功能感覺還不錯,挺方便的。
具體是怎么實現(xiàn)的呢,去網(wǎng)上大概查了一下。
這個是使用滾動條屬性scrollTop來實現(xiàn)的。
基本實現(xiàn)流程:滾動條移動的時候,將滾動條實時的位置存入Cookie或者localstorage中,但是一些老舊的瀏覽器版本對localstorage支持不是特別友好。
如果你想使用localstorage來實現(xiàn),請參照《VUE自學(xué)筆記之使用localstorage和sessionstorage實現(xiàn)登錄》
我這里使用的是cookie來存儲。
這里有兩個方法
方法一:這個比較集中
/** * @name: 控制 瀏覽器滾動條 * @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ù)
這個將cookie的存取各封裝成了一個函數(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");//頁面加載時設(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; }
其實這個就是一個對cookie存儲和取值以及scrollTop賦值的一個過程,不是很難。
上邊的兩段代碼,一般情況下,只要放到你的項目里邊就能好用。
如果不好用,請重新檢查一下,你的項目中是否還有別的地方對scrollTop賦值。
以上就是JS實現(xiàn)刷新網(wǎng)頁后之前瀏覽位置保持不變示例詳解的詳細(xì)內(nèi)容,更多關(guān)于JS刷新網(wǎng)頁瀏覽位置保持的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
uniApp學(xué)習(xí)之熱門搜索,搜索數(shù)據(jù)頁面緩存實例
這篇文章主要介紹了uniApp學(xué)習(xí)之熱門搜索,搜索數(shù)據(jù)頁面緩存實例,需要的朋友可以參考下2023-10-10