jQuery: 如何从文章中的每个标题自动添加 LI 元素

jQuery: How to add automatically LI elements from each heading in article

我想在每个博客 post 中实现 "ScrollSpy"(我使用 Materialise)。我认为最好的实现是 jQuery。但是,我正在努力使其充满活力。所以,到目前为止,我有这段代码。

$('body.single .entry-content').append('<div class="col hide-on-small-only m3 l2"><ul class="section table-of-contents"></ul></div>');

var h2 = $('.entry-content').find('h2').text();
var h3 = $('.entry-content').find('h3').text();

$('ul.table-of-contents').append("<li><a href='#" +h2 +"'>" +h2 +"</a></li>");
$('ul.table-of-contents').append("<li><a href='#" +h3 +"'>" +h3 +"</a></li>");

如何根据 h2、h3、h4 等的数量使其动态化?

您可以遍历 header 元素,然后添加 li 元素,例如:

var html = '';
$('.entry-content').find('h2, h3, h4, h5').each(function() {
  var header = $(this).text();
  html += "<li><a href='#" + header + "'>" + header + "</a></li>";
});
$('ul.table-of-contents').append(html);

您可以尝试以下方块

$('body.single .entry-content').append('<div class="col hide-on-small-only m3 l2"><ul class="section table-of-contents"></ul></div>');

$(".entry-header h2, .entry-header h3").each(function (index) {
    var $this = $(this), ID = "header" + index;
    $this.attr("id", ID);
    $("ul.table-of-contents").append(
        $("<li/>").append($("<a/>").attr("href", "#" + ID).text(h2.text());
    );
});

未测试:

假设您想升至 h4

For (var i=0;i<=4;i++){
var hTag= 'h' + i.toString();
hText=    $('.entry-content').find('hTag').text();
$('ul.table-of-contents').append("<li><a href='#" +hText +"'>" +hText +"</a></li>");

}