【问题标题】:Scroll to anchor滚动到锚点
【发布时间】:2010-04-14 04:39:06
【问题描述】:

我有以下 userjs,旨在删除 URL 的锚部分,但仍跳转到它:

// ==UserScript==
// @name PurgeAnchor
// @include *
// ==/UserScript==
(function() {
 var reg=/^(.*)\#(.*)$/;
 var match=reg.exec(location);
 function ObjectPosition(obj) {
    var curtop = 0;
    if(obj.offsetParent)
        while(1)
        {
          curtop += obj.offsetTop;
          if(!obj.offsetParent)
            break;
          obj = obj.offsetParent;
        }
    else if(obj.y)
        curtop += obj.y;
    return curtop;
 }
 if(match) {
    document.location.replace(match[1]);
    sessionStorage.setItem("anchor", match[2]);
 }
 window.addEventListener("load", (function() {
         var anchor=sessionStorage.getItem("anchor");
         if(anchor!==null) {
             var obj=document.anchors.item(anchor);
             // var obj=document.getElementById(anchor);
             // if(obj===null) {
                 // obj=document.getElementsByName(anchor)[0];
             // }
             var pos=0;
             if(obj!==null) {
                 pos=ObjectPosition(obj);
                 window.scrollTo(0, pos);
             }
             sessionStorage.removeItem("anchor");
         }
     }), false);
 })()

问题是,如果我有一个空的<a> 标记并设置了名称,它将无法跳转。 obj.scrollIntoView() 也失败了。 Opera-10.52_pre6306,Gentoo。

【问题讨论】:

  • 一目了然,你想要 document.anchors.namedItem(anchor) 而不是 document.anchors.item(anchor)
  • 问题是,如果我输入alert(obj.outerHTML),我会得到正确的项目,比如<a name="tab-top"></a>。但是为了滚动,我必须在前面加上obj.innerHTML="a";,否则它会失败。如果我没有 emty diva,它工作正常。而且,是的,你的建议没有帮助。
  • 我想这可能是一个歌剧错误。

标签: javascript anchor opera userjs


【解决方案1】:

好的,花了一段时间,但我想我终于明白了:

(function detectSaveAndRedirect() {
            window.addEventListener('load', function() {
                // If the URL already has a hash, remove it.
                if (location.hash.length > 0) {
                    sessionStorage.setItem('anchor',location.hash.substr(1))
                    location.hash = ''
                }
                window.addEventListener('hashchange', function(event) {
                    if (sessionStorage.getItem('anchor')) {
                        event.preventDefault();
                        document.getElementById(sessionStorage.getItem('anchor')).scrollIntoView()
                        sessionStorage.removeItem('anchor')
                    }
                });
                // If links have hashes, remove them.
                document.getElementsByTagName('a').forEach(function(a) {
                    if (
                        (new URL(a.href).host == location.host) &&
                        (a.hash.length > 0)
                    ) {
                        a.addEventListener('click',function(event) {
                            a.removeAttribute('href')
                            a.scrollIntoView();
                        });
                    }
                });
            })
        })()

【讨论】:

    猜你喜欢
    • 2017-11-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-08-06
    • 1970-01-01
    • 1970-01-01
    • 2020-10-17
    • 1970-01-01
    相关资源
    最近更新 更多