让博客园博客自动生成章节目录索引
討論QQ群:135202158
對于比較長的文章,有一個(gè)好的目錄索引是很有必要的,可以讓讀者比較清楚地了解文章內(nèi)容和層次。然而,目前(2015.7)博客園不像csdn博客那樣,會(huì)對發(fā)布的文章自動(dòng)生成目錄索引。不過,一些網(wǎng)友通過博客園后臺(tái)提供的一些自定義功能,自己寫腳本實(shí)現(xiàn)了這一功能。我用的腳本主要就是參考@薰衣草的旋律 的,文章地址是:http://www.cnblogs.com/wangqiguo/p/4355032.html。
原作者的腳本只支持1級目錄,我改了兩級:第1級是h2,第2級是h3。還添加了一些小玩意,比如討論qq群號。效果如下圖所示:
添加功能的具體步驟是:
確保自己的博客園后臺(tái)支持js
這個(gè)默認(rèn)是不支持,需要向官方發(fā)個(gè)郵件申請開通(郵箱是contact@cnblogs.com),我簡單寫了封郵件,1小時(shí)就回復(fù)了,郵件內(nèi)容我只寫了兩個(gè)字:如題。。。。
到后臺(tái)加入腳本
打開博客園后臺(tái),進(jìn)入“設(shè)置”標(biāo)簽頁,在最下面的“頁腳Html代碼”對應(yīng)的編輯框粘貼你的js代碼,然后點(diǎn)“保存”按鈕保存。
按格式寫文章
在寫新博文的時(shí)候,注意按照你js腳本里設(shè)定的格式來劃分章節(jié),比如h2,h3等。當(dāng)然,以前發(fā)布的文章如果有h2,h3之類,也會(huì)自動(dòng)生成目錄索引。
腳本如下:
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 h2');//如果你的章節(jié)標(biāo)題不是h2,只需要將這里的h2換掉即可
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><b>目錄</b></p>';
19 content += '<ul>';
20 for(var i=0; i<h2_list.length; i++)
21 {
22 var go_to_top = '<div><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("h3");
26 var li3_content = '';
27 for(var j=0; j<h3_list.length; j++)
28 {
29 var tmp = $(h3_list[j]).prevAll('h2').first();
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'%20+%20i%20+%20'_'%20+%20j%20+%20'">' + $(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'%20+%20i%20+%20'">' + $(h2_list[i]).text() + '</a><ul>' + li3_content + '</ul></li>';
40 else
41 li2_content = '<li><a href="#_label'%20+%20i%20+%20'">' + $(h2_list[i]).text() + '</a></li>';
42 content += li2_content;
43 }
44 content += '</ul>';
45 content += '</div><p> </p>';
46 content += '<p><b>正文</b></p>';
47 if($('#cnblogs_post_body').length != 0 )
48 {
49 $($('#cnblogs_post_body')[0]).prepend(content);
50 }
51 }
52
53 var qqinfo = '<p>討論QQ群:135202158</p>';
54 $(mainContent[0]).prepend(qqinfo);
55 }
56
57 GenerateContentList();
58 </script>
【參考】@薰衣草的旋律: http://www.cnblogs.com/wangqiguo/p/4355032.html
總結(jié)
以上是生活随笔為你收集整理的让博客园博客自动生成章节目录索引的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SAP CRM呼叫中心里的Java st
- 下一篇: 如何使用For和Set参数