刷新页面并保持滚动位置

chr*_*iec 39 html javascript

有人能告诉我我做错了什么吗?我需要在一段时间后刷新页面,但它刷新到页面顶部,我需要它不改变页面位置!所以这就是我现在没有工作的是meta标签吗?这是我没有仍然不刷新必须做错的事情?

这是我原来的......

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
    <head>
        <meta http-equiv="refresh" content="72">
        <meta http-equiv="Pragma" CONTENT="no-cache">
        <meta http-equiv="Expires" CONTENT="-1">

        <style type="text/css">
        body
        { 
            background-image: url('../Images/Black-BackGround.gif');
            background-repeat: repeat;
        }
        </style>
    </head>

    <script type="text/javascript">

    function saveScrollPositions(theForm) {
        if(theForm) {
            var scrolly = typeof window.pageYOffset != 'undefined' ? window.pageYOffset
                                                   : document.documentElement.scrollTop;
            var scrollx = typeof window.pageXOffset != 'undefined' ? window.pageXOffset
                                                  : document.documentElement.scrollLeft;
            theForm.scrollx.value = scrollx;
            theForm.scrolly.value = scrolly;
        }
    }
    </script>

 <form action="enroll.php" name="enrollment" method="post" onsubmit="return saveScrollPositions (this);">
  <input type="hidden" name="scrollx" id="scrollx" value="0" />
  <input type="hidden" name="scrolly" id="scrolly" value="0" />

  <STYLE type="text/css">
   #Nav a{ position:relative; display:block; text-decoration: none; color:Black; }
   Body td{font-Family: Arial; font-size: 12px; }
  </style>
Run Code Online (Sandbox Code Playgroud)

在阅读了一些初步答案后,我将其更改为...

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>

<style type="text/css">
body
{ 
    background-image: url('../Images/Black-BackGround.gif');
    background-repeat: repeat;
}
</style>
</head>


<script>
function refreshPage () {
    var page_y = $( document ).scrollTop();
    window.location.href = window.location.href + '?page_y=' + page_y;
}
window.onload = function () {
    setTimeout(refreshPage, 35000);
    if ( window.location.href.indexOf('page_y') != -1 ) {
        var match = window.location.href.split('?')[1].split("&")[0].split("=");
        $('html, body').scrollTop( match[1] );
    }
}
</script>

<STYLE type="text/css">
#Nav a{ position:relative; display:block; text-decoration: none; color:black; }
Body td{font-Family: Arial; font-size: 12px; }
</style>
Run Code Online (Sandbox Code Playgroud)

pow*_*tac 33

document.location.reload()存储位置,但在文档中没有提到.

添加其他true参数以强制重新加载.

document.location.reload(true)
Run Code Online (Sandbox Code Playgroud)

  • 仅适用于我的 Chrome,最新的 FF 或 Edge 均不保留滚动位置,而是滚动到顶部 (4认同)
  • 现在 MDN 上提到了这一点。 (2认同)
  • @trysis 在哪里?在 https://developer.mozilla.org/en-US/docs/Web/API/Location/reload$compare?locale=en-US&amp;to=788646&amp;from=471047 上看不到它 (2认同)
  • 它位于您答案中链接的页面上。他们称之为“forcedReload”。 (2认同)
  • 文档说“在强制模式下(当参数设置为 true 时),新的 DOM 会加载scrollTop == 0。” - 这听起来不像它保持滚动位置。我没有时间测试它,所以我可能会错过一些东西...... (2认同)
  • Internet Explorer 不保存位置。我用了@zingle-dingle的答案 (2认同)

San*_*tha 28

这会变魔术

    <script>
        document.addEventListener("DOMContentLoaded", function(event) { 
            var scrollpos = localStorage.getItem('scrollpos');
            if (scrollpos) window.scrollTo(0, scrollpos);
        });

        window.onbeforeunload = function(e) {
            localStorage.setItem('scrollpos', window.scrollY);
        };
    </script>
Run Code Online (Sandbox Code Playgroud)

  • 非常好的和简单的解决方案。我做了一些改变。即使浏览器关闭后,浏览器仍会存储这些数据。我用 sessionStorage 替换了 localStorage,并在设置滚动位置后使用 sessionStorage.removeItem('scrollpos') 清除了它。这确保了浏览器关闭后滚动位置被清除。我将修改后的代码发布为单独的答案。 (4认同)
  • 如果您想保留 div 等元素的滚动位置,可以使用相同的技术来设置元素的“scrollTop”属性。 (2认同)

kke*_*ple 11

如果您不想使用本地存储,那么您可以将页面的y位置附加到URL并在加载时使用js抓取它并将页面偏移设置为您传入的get参数,即:

//code to refresh the page
var page_y = $( document ).scrollTop();
window.location.href = window.location.href + '?page_y=' + page_y;


//code to handle setting page offset on load
$(function() {
    if ( window.location.href.indexOf( 'page_y' ) != -1 ) {
        //gets the number from end of url
        var match = window.location.href.split('?')[1].match( /\d+$/ );
        var page_y = match[0];

        //sets the page offset 
        $( 'html, body' ).scrollTop( page_y );
    }
});
Run Code Online (Sandbox Code Playgroud)


zin*_*gle 7

这也可能对刷新很有用.但是,如果您想在单击相同位置之前跟踪页面上的位置..以下代码将有所帮助.

还添加了一个数据确认,提示用户是否真的想要这样做.

注意:我正在使用jQuery和js-cookie.js来存储cookie信息.

$(document).ready(function() {
    // make all links with data-confirm prompt the user first.
    $('[data-confirm]').on("click", function (e) {
        e.preventDefault();
        var msg = $(this).data("confirm");
        if(confirm(msg)==true) {
            var url = this.href;
            if(url.length>0) window.location = url;
            return true;
        }
        return false;
    });

    // on certain links save the scroll postion.
    $('.saveScrollPostion').on("click", function (e) {
        e.preventDefault();
        var currentYOffset = window.pageYOffset;  // save current page postion.
        Cookies.set('jumpToScrollPostion', currentYOffset);
        if(!$(this).attr("data-confirm")) {  // if there is no data-confirm on this link then trigger the click. else we have issues.
            var url = this.href;
            window.location = url;
            //$(this).trigger('click');  // continue with click event.
        }
    });

    // check if we should jump to postion.
    if(Cookies.get('jumpToScrollPostion') !== "undefined") {
        var jumpTo = Cookies.get('jumpToScrollPostion');
        window.scrollTo(0, jumpTo);
        Cookies.remove('jumpToScrollPostion');  // and delete cookie so we don't jump again.
    }
});
Run Code Online (Sandbox Code Playgroud)

像这样使用它的一个例子.

<a href='gotopage.html' class='saveScrollPostion' data-confirm='Are you sure?'>Goto what the heck</a>
Run Code Online (Sandbox Code Playgroud)


小智 7

谢谢 Sanoj,这对我有用。
但是 iOS 不支持 iPhone 上的“onbeforeunload”。我的解决方法是使用 js 设置 localStorage:

<button onclick="myFunction()">Click me</button>

<script>
document.addEventListener("DOMContentLoaded", function(event) { 
            var scrollpos = localStorage.getItem('scrollpos');
            if (scrollpos) window.scrollTo(0, scrollpos);
        });
function myFunction() {
  localStorage.setItem('scrollpos', window.scrollY);
  location.reload(); 
}
</script>
Run Code Online (Sandbox Code Playgroud)


Sha*_*313 6

更新

您可以使用document.location.reload(true)下面提到的方法代替下面的强制技巧。

将HTML替换为:

<!DOCTYPE html>
<html>
    <head>
        <style type="text/css">
            body { 
                background-image: url('../Images/Black-BackGround.gif');
                background-repeat: repeat;
            }
            body td {
               font-Family: Arial; 
               font-size: 12px; 
            }
            #Nav a { 
                position:relative; 
                display:block; 
                text-decoration: none; 
                color:black; 
            }
        </style>
        <script type="text/javascript">
            function refreshPage () {
                var page_y = document.getElementsByTagName("body")[0].scrollTop;
                window.location.href = window.location.href.split('?')[0] + '?page_y=' + page_y;
            }
            window.onload = function () {
                setTimeout(refreshPage, 35000);
                if ( window.location.href.indexOf('page_y') != -1 ) {
                    var match = window.location.href.split('?')[1].split("&")[0].split("=");
                    document.getElementsByTagName("body")[0].scrollTop = match[1];
                }
            }
        </script>
    </head>
    <body><!-- BODY CONTENT HERE --></body>
</html>
Run Code Online (Sandbox Code Playgroud)


Ben*_*Ben 6

我修改了 Sanoj Dushmantha 的答案以使用 sessionStorage 而不是 localStorage。然而,尽管有文档,即使浏览器关闭,浏览器仍会存储这些数据。为了解决这个问题,我在重置后删除了滚动位置。

<script>
    document.addEventListener("DOMContentLoaded", function (event) {
        var scrollpos = sessionStorage.getItem('scrollpos');
        if (scrollpos) {
            window.scrollTo(0, scrollpos);
            sessionStorage.removeItem('scrollpos');
        }
    });

    window.addEventListener("beforeunload", function (e) {
        sessionStorage.setItem('scrollpos', window.scrollY);
    });
</script>
Run Code Online (Sandbox Code Playgroud)