• 页面的div中有滚动条,js实现刷新页面后回到记录时滚动条的位置


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

    第一种方案

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

    js代码:

    复制代码

    <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中代码如下:

    复制代码

    <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>

    复制代码

    第二种方案

      1.通过div的onscroll事件记录滚动条的scrollTop值,设置到document.cookie
      2.页面加载时再读取document.cookie的值,设置给div的scrollTop

    js代码实现:

    复制代码

    <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:

    复制代码

    <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>

    复制代码

  • 相关阅读:
    C# 使用NPOI 实现Excel的简单导入导出
    C# 根据Excel模版导出文件
    移动通信第九组网络抓包作业
    武金龙老师的教导(第9小组)
    【Python核心编程笔记】一、Python中一切皆对象
    自己喜欢的几个前端框架
    2018-1-6-个人博客、博客园、微信公众号、Github、本地同步写博客
    2018-1-6-IDEA快速代码生成
    CodeMirror动态修改代码(关键: editor.getDoc().setValue(data); editor.refresh();)
    FaceId枚举表(用于VBA的加载项)
  • 原文地址:https://www.cnblogs.com/zhaohongtian/p/6802352.html
Copyright © 2020-2023  润新知