2017.5.3 博客园自动生成章节目录

时间:2022-10-16 12:23:32

参考来自:http://www.cnblogs.com/zzqcn/p/4657124.html

 

1.效果图

2017.5.3 博客园自动生成章节目录

2.申请js权限

 写邮件给contact@cnblogs.com。

2017.5.3 博客园自动生成章节目录

 

3.复制代码至页脚html

这里处理了h3和h4的标题,如有自己的需求,只需要更改js代码里的h3,h4。

 1 <script language="javascript" type="text/javascript">
2
3 // 生成目录索引列表
4 // ref: http://www.cnblogs.com/wangqiguo/p/4355032.html
5 // modified by: zzq
6 function GenerateContentList()
7 {
8 var mainContent = $('#cnblogs_post_body');
9 var h2_list = $('#cnblogs_post_body h3');//如果你的章节标题不是h3,只需要将这里的h3换掉即可
10
11 if(mainContent.length < 1)
12 return;
13
14 if(h2_list.length>0)
15 {
16 var content = '<a name="_labelTop"></a>';
17 content += '<div id="navCategory">';
18 content += '<p style="font-size:18px"><b>目录</b></p>';
19 content += '<ul>';
20 for(var i=0; i<h2_list.length; i++)
21 {
22 var go_to_top = '<div style="text-align: right"><a href="#_labelTop">回到顶部</a><a name="_label' + i + '"></a></div>';
23 $(h2_list[i]).before(go_to_top);
24
25 var h3_list = $(h2_list[i]).nextAll("h4");//如果你的章节标题不是h4,只需要将这里的h4换掉即可
26 var li3_content = '';
27 for(var j=0; j<h3_list.length; j++)
28 {
29 var tmp = $(h3_list[j]).prevAll('h3').first();//如果你的章节标题不是h3,只需要将这里的h3换掉即可
30 if(!tmp.is(h2_list[i]))
31 break;
32 var li3_anchor = '<a name="_label' + i + '_' + j + '"></a>';
33 $(h3_list[j]).before(li3_anchor);
34 li3_content += '<li><a href="#_label' + i + '_' + j + '">' + $(h3_list[j]).text() + '</a></li>';
35 }
36
37 var li2_content = '';
38 if(li3_content.length > 0)
39 li2_content = '<li><a href="#_label' + i + '">' + $(h2_list[i]).text() + '</a><ul>' + li3_content + '</ul></li>';
40 else
41 li2_content = '<li><a href="#_label' + i + '">' + $(h2_list[i]).text() + '</a></li>';
42 content += li2_content;
43 }
44 content += '</ul>';
45 content += '</div><p>&nbsp;</p>';
46 content += '<p style="font-size:18px"><b>正文</b></p>';
47 if($('#cnblogs_post_body').length != 0 )
48 {
49 $($('#cnblogs_post_body')[0]).prepend(content);
50 }
51 }
52 }
53
54 GenerateContentList();
55 </script>

 

4.写随笔时设置标题格式为-标题*

 就会自动生成目录了。