html刷新页面保持原来位置,js实现刷新页面后回到记录时滚动条的位置【两种方案可选】...

当div中绑定数据,给它一个属性overflow-y: scroll,添加长度大小,使其能够出现滚动条;每次刷新的时候滚动条总是会出现在最上方,这使我很头疼,经过查阅网上资料,返现两种方法可行。如下:

第一种方案

将上一个页面的div的scrolltop距离长度记录在cookie中,然后通过js调整刷新页面时的长度记录,代码如下:

js代码:

var _h = 0;

function SetH(o) {

_h = o.scrollTop

SetCookie("a", _h)

}

window.onload = function () {

document.getElementById("x").scrollTop = GetCookie("a");//页面加载时设置scrolltop高度

}

function SetCookie(sName, sValue) {

document.cookie = sName + "=" + escape(sValue) + "; ";

}

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;

}

html中代码如下:

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

第二种方案

1.通过div的onscroll事件记录滚动条的scrollTop值,设置到document.cookie

2.页面加载时再读取document.cookie的值,设置给div的scrollTop

js代码实现:

function KeepScrollBar() {

var scrollPos;

if (typeof window.pageYOffset != 'undefined') {

scrollPos = window.pageYOffset;

}

else if (typeof document.body != 'undefined') {

scrollPos = document.getElementById('divContent').scrollTop;

}

document.cookie = "scrollTop=" + scrollPos;

}

window.onload = function (){

if (document.cookie.match(/scrollTop=([^;]+)(;|$)/) != null) {

var arr = document.cookie.match(/scrollTop=([^;]+)(;|$)/);

document.getElementById('divContent').scrollTop = parseInt(arr[1]);

}

}

html:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值