微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何从页面 URL 中删除哈希值并在重新加载时重置窗口的偏移量

如何解决如何从页面 URL 中删除哈希值并在重新加载时重置窗口的偏移量

我对 html 的锚元素有问题。当我重新加载页面时,URL 继续使用锚元素的哈希值,并且窗口偏移量不会回到顶部。我认为浏览器知道这是一个页面,因此不会重新加载到窗口的原始偏移位置。这是我的代码

   <nav class="desktopMenu">
    <ul>
      <a href="#home">
        <li>Home</li>
      </a>
      <a href="#about">
        <li>About</li>
      </a>
      <a href="#abilities">
        <li>Abilities</li>
      </a>
      <a href="#gameplay">
        <li>Gameplay</li>
      </a>
    </ul>
  </nav>

因此,我尝试使用以下方法清除 URL 中的哈希值:

  window.location.hash = '';
  $(window).offset().top = 0; 

它会清除哈希之后的内容,但不会重置窗口偏移量。

解决方法

您可以通过以下方式滚动到页面顶部:

$([document.documentElement,document.body]).animate({
  scrollTop: 0
},0);

一个例子:

https://jsfiddle.net/praveen_tamil/s0qu8n2t/2/

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。