JS實(shí)現(xiàn)刷新網(wǎng)頁后之前瀏覽位置保持不變示例詳解
正文
在京東上瀏覽的時(shí)候,發(fā)現(xiàn)了一個(gè)比較人性化的小功能,瀏覽商品,瀏覽到一半的時(shí)候,如下圖所示:

我重新加載網(wǎng)頁,刷新之后,滾動(dòng)條依然定位在我剛剛瀏覽的位置,這個(gè)小功能感覺還不錯(cuò),挺方便的。
具體是怎么實(shí)現(xiàn)的呢,去網(wǎng)上大概查了一下。
這個(gè)是使用滾動(dòng)條屬性scrollTop來實(shí)現(xiàn)的。
基本實(shí)現(xiàn)流程:滾動(dòng)條移動(dòng)的時(shí)候,將滾動(dòng)條實(shí)時(shí)的位置存入Cookie或者localstorage中,但是一些老舊的瀏覽器版本對localstorage支持不是特別友好。
如果你想使用localstorage來實(shí)現(xiàn),請參照《VUE自學(xué)筆記之使用localstorage和sessionstorage實(shí)現(xiàn)登錄》
我這里使用的是cookie來存儲。
這里有兩個(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");//頁面加載時(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è)對cookie存儲和取值以及scrollTop賦值的一個(gè)過程,不是很難。
上邊的兩段代碼,一般情況下,只要放到你的項(xiàng)目里邊就能好用。
如果不好用,請重新檢查一下,你的項(xiàng)目中是否還有別的地方對scrollTop賦值。
以上就是JS實(shí)現(xiàn)刷新網(wǎng)頁后之前瀏覽位置保持不變示例詳解的詳細(xì)內(nèi)容,更多關(guān)于JS刷新網(wǎng)頁瀏覽位置保持的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序 保留小數(shù)(toFixed)詳細(xì)介紹
這篇文章主要介紹了 微信小程序 保留小數(shù)(toFixed)詳細(xì)介紹的相關(guān)資料,這里附有實(shí)例,幫助大家學(xué)習(xí)參考此部分知識,需要的朋友可以參考下2016-11-11
微信小程序 判斷手機(jī)號的實(shí)現(xiàn)代碼
這篇文章主要介紹了微信小程序 判斷手機(jī)號的實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2017-04-04
一個(gè)很簡單的辦法實(shí)現(xiàn)TD的加亮效果.
一個(gè)很簡單的辦法實(shí)現(xiàn)TD的加亮效果....2006-06-06

