当锚在URL中时,避免页面滚动/跳转

Ben*_*Ben 14 javascript anchor jquery

可能重复:
jquery - 加载页面时禁用锚点"跳转"

我正在显示一个div,具体取决于URL中的哈希值,但我想避免页面跳转到具有该特定ID的div的位置.

我只是在直接使用URL中的哈希导航页面时遇到问题,所以例如,如果某人有书标记了页面.

例如,我有url domain.com/page.html#myitem-1

然后会显示ID = myitem-1,但是页面会跳转到我不想要的div的位置.

我试图使用scrollTop(0)强制窗口位置回到顶部,但似乎在锚点跳转发生之前调用它是没有效果的

示例代码:

  $(document).ready(function() {
    $('.glossary-term').hide();
    $(window.location.hash).show();

    $(window).scrollTop(0);

});
Run Code Online (Sandbox Code Playgroud)

我能够让这个scrollTop工作的唯一方法是将它放在持续时间为1的setTimeOut中,但这看起来有点像黑客.还有其他建议吗?

谢谢

Maj*_*jki 10

好吧,如果你的内部机制只是用于显示div,你可以随时更改(或删除)"name"属性,这样浏览器就不会直接找到它,也不会尝试滚动;)

否则尝试如何在加载页面时禁用锚点"跳转"?