Posted in Javascript onAugust 14, 2022
正文
在京东上浏览的时候,发现了一个比较人性化的小功能,浏览商品,浏览到一半的时候,如下图所示:
我重新加载网页,刷新之后,滚动条依然定位在我刚刚浏览的位置,这个小功能感觉还不错,挺方便的。
具体是怎么实现的呢,去网上大概查了一下。
这个是使用滚动条属性scrollTop来实现的。
基本实现流程:滚动条移动的时候,将滚动条实时的位置存入Cookie或者localstorage中,但是一些老旧的浏览器版本对localstorage支持不是特别友好。
如果你想使用localstorage来实现,请参照《VUE自学笔记之使用localstorage和sessionstorage实现登录》
我这里使用的是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存取各封装成函数
这个将cookie的存取各封装成了一个函数,调用更灵活。
window.onscroll = function() {
var scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;
SetCookie("a", scrollTop);
}
window.onload = function () {
document.body.scrollTop = GetCookie("a");//页面加载时设置scrolltop高度
}
/**
* @name: 设置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实现刷新网页后之前浏览位置保持不变示例详解的详细内容,更多关于JS刷新网页浏览位置保持的资料请关注三水点靠木其它相关文章!
JS实现刷新网页后之前浏览位置保持不变示例详解
- Author -
camellia- Original Sources -
声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@