讓博客園博客自動生成章節目錄索引

 

對於比較長的文章,有一個好的目錄索引是頗有必要的,能夠讓讀者比較清楚地瞭解文章內容和層次。然而,目前(2015.7)博客園不像csdn博客那樣,會對發佈的文章自動生成目錄索引。不過,一些網友經過博客園後臺提供的一些自定義功能,本身寫腳本實現了這一功能。我用的腳本主要就是參考@薰衣草的旋律 的,文章地址是:http://www.cnblogs.com/wangqiguo/p/4355032.html。javascript

原做者的腳本只支持1級目錄,我改了兩級:第1級是h2,第2級是h3。還添加了一些小玩意,好比討論qq羣號。效果以下圖所示:html

 

 

添加功能的具體步驟是:java

    1. 確保本身的博客園後臺支持js
      這個默認是不支持,須要向官方發個郵件申請開通(郵箱是contact@cnblogs.com),我簡單寫了封郵件,1小時就回復了,郵件內容我只寫了兩個字:如題。。。。
    2. 到後臺加入腳本
      打開博客園後臺,進入「設置」標籤頁,在最下面的「頁腳Html代碼」對應的編輯框粘貼你的js代碼,而後點「保存」按鈕保存。
    3. 按格式寫文章
      在寫新博文的時候,注意按照你js腳本里設定的格式來劃分章節,好比h2,h3等。固然,之前發佈的文章若是有h2,h3之類,也會自動生成目錄索引。

 

 

腳本以下:post

 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');//若是你的章節標題不是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 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("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' + 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     var qqinfo =  '<p style="color:navy;font-size:12px">討論QQ羣:135202158</p>';
54     $(mainContent[0]).prepend(qqinfo);
55 }
56 
57 GenerateContentList();
58 </script>

 

【參考】@薰衣草的旋律: http://www.cnblogs.com/wangqiguo/p/4355032.html
相關文章
相關標籤/搜索