使用锚名称的jQuery目录插件

时间:2014-06-05 07:44:49

标签: javascript jquery tableofcontents

我正在寻找一个使用给定锚名称的jQuery目录插件。我发现的那些总是生成他们自己的锚名称,导致不稳定的URI,如somewhere#toc_1_4。但对于像这样的锚

<h2><a name="something-special">Something Special</a></h2>

我想要一个像somewhere#something-special这样的URI。

有这样的插件吗?

2 个答案:

答案 0 :(得分:5)

我不知道这样的插件,但这可以很容易地完成:

$('a[name]').each(function(i, v) {
    var e = $(v);
    if (e.text() != '') {
        $('#toc').append('<li><a href="#' + e.attr('name') + '">' + e.text() + '</a></li>');
    }
});

对于每个链接,将一个列表项附加到#toc(可以是有序列表):

<h1>Table of contents:</h1>
<ol id="toc"></ol>

您还可以添加以下内容:

<a name="something-special" data-toc="yes" data-title="Special topic">special</a>

并使用代码:

$('a[name]').each(function(i, v) {
    var e = $(v);
    var t = e.data('title') || e.text();
    if (e.data('toc') == 'yes' && t.length > 0) {
        $('#toc').append('<li><a href="#' + e.attr('name') + '">' + t + '</a></li>');
    }
});

这是一个jsfiddle:http://jsfiddle.net/27Ubt/1/

答案 1 :(得分:2)

考虑一下这个插件:

希望它有所帮助。