我正在寻找一个使用给定锚名称的jQuery目录插件。我发现的那些总是生成他们自己的锚名称,导致不稳定的URI,如somewhere#toc_1_4
。但对于像这样的锚
<h2><a name="something-special">Something Special</a></h2>
我想要一个像somewhere#something-special
这样的URI。
有这样的插件吗?
答案 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)