html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

js实现刷新页面后回到记录时滚动条的位置【两种方案可选】_javascript技巧_

[ ] 已经帮助:人解决问题

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

第一种方案tCeHTML5中文学习网 - HTML5先行者学习网

将上一个页面的div的scrolltop距离长度记录在cookie中,然后通过js调整刷新页面时的长度记录,代码如下:tCeHTML5中文学习网 - HTML5先行者学习网

js代码:tCeHTML5中文学习网 - HTML5先行者学习网

<script>  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;  } </script>

html中代码如下:tCeHTML5中文学习网 - HTML5先行者学习网

<div id="x" style="height: 200px; overflow: scroll" onscroll="SetH(this)">   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p>   <p>1</p></div>

第二种方案tCeHTML5中文学习网 - HTML5先行者学习网

1.通过div的onscroll事件记录滚动条的scrollTop值,设置到document.cookietCeHTML5中文学习网 - HTML5先行者学习网

2.页面加载时再读取document.cookie的值,设置给div的scrollToptCeHTML5中文学习网 - HTML5先行者学习网

js代码实现:tCeHTML5中文学习网 - HTML5先行者学习网

<script type="text/javascript">  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]);    }  }</script>

html:tCeHTML5中文学习网 - HTML5先行者学习网

<div class="content" data-role="tab-content" data-id="course-a" runat="server" id="divContent" style="height: 365px; overflow-y: scroll" onscroll= "KeepScrollBar()">    <p>   1</p>       <p>   2</p>       <p>   3</p>       <p>   4</p>       <p>   5</p>       <p>   6</p>       <p>   7</p>       <p>   8</p>       <p>   9</p>       <p>   10</p>       <p>   11</p>       <p>   12</p>       <p>   13</p>       <p>   14</p>       <p>   15</p>       <p>   16</p> </div>

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

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助