用before方法javascript
30 var li3_anchor = '<a name="_label' + i + '_' + j + '"></a>'; //添加锚点 31 $(h3_list[j]).before(li3_anchor);
a标签的href属性到锚点a标签的name属性html
32 li3_content += '<li><a href="#_label' + i + '_' + j + '">' 33 + $(h3_list[j]).text() + '</a></li>'; //连接到锚点
prepend内部以前插入方法java
99 var title_h1 = $('#cnblogs_post_body h1');//将标题信息插入到开头 100 $(mainContent[0]).prepend(title_h1[0]);
实现原理:在页脚添加了一个js函数,而后调用执行,用了不少类选择器和dom里面的知识, 里面有jqueryjquery
对于比较长的文章,有一个好的目录索引是颇有必要的,可让读者比较清楚地了解文章内容和层次。然而,目前(2015.7)博客园不像csdn博客那样,会对发布的文章自动生成目录索引。不过,一些网友经过博客园后台提供的一些自定义功能,本身写脚本实现了这一功能。我用的脚本主要就是参考@薰衣草的旋律 的,文章地址是:http://www.cnblogs.com/wangqiguo/p/4355032.html。dom
原做者的脚本只支持1级目录,我改了两级:第1级是h2,第2级是h3。还添加了一些小玩意,好比讨论qq群号。效果以下图所示:函数
添加功能的具体步骤是: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> </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.htmlspa
参考:code
让博客园博客自动生成章节目录索引 - 赵子清 - 博客园
https://www.cnblogs.com/zzqcn/p/4657124.html
修改了一下上面的代码
1 <!-- 自动生成目录 --> 2 <script language="javascript" type="text/javascript"> 3 // 生成目录索引列表 4 // ref: http://www.cnblogs.com/wangqiguo/p/4355032.html 5 // modified by: zzq 6 // ref: https://www.cnblogs.com/zzqcn/p/4657124.html 7 // modified by: fry 8 function GenerateContentList() { 9 var mainContent = $('#cnblogs_post_body'); 10 var h2_list = $('#cnblogs_post_body h2');//若是你的章节标题不是h2,只须要将这里的h2换掉便可 11 12 if (mainContent.length < 1) 13 return; 14 15 if (h2_list.length > 0) { 16 var content = '<a name="_labelTop"></a>'; 17 content += '<div id="navCategory">'; 18 content += '<p ><h2>目录</h2></p>'; 19 content += '<ul>'; 20 for ( var i = 0; i < h2_list.length; i++) { 21 var go_to_top = '<div style="text-align: right"><a href="#_labelTop">回到顶部</a><a name="_label' + i + '"></a></div>'; //在h2上添加回到顶部 22 $(h2_list[i]).before(go_to_top); 23 24 var h3_list = $(h2_list[i]).nextAll("h3"); 25 var li3_content = ''; 26 for ( var j = 0; j < h3_list.length; j++) { 27 var tmp = $(h3_list[j]).prevAll('h2').first(); //找h3的所属父亲h2 28 if (!tmp.is(h2_list[i])) //若是h3不是当前这个h2的孩子 29 break; 30 var li3_anchor = '<a name="_label' + i + '_' + j + '"></a>'; //添加锚点 31 $(h3_list[j]).before(li3_anchor); 32 li3_content += '<li><a href="#_label' + i + '_' + j + '">' 33 + $(h3_list[j]).text() + '</a></li>'; //连接到锚点 34 } 35 36 var li2_content = ''; 37 if (li3_content.length > 0) //若是当前h2有h3,那么h2和h3的内容都加到目录 38 li2_content = '<li><a href="#_label' + i + '">' 39 + $(h2_list[i]).text() + '</a><ul>' + li3_content 40 + '</ul></li>'; 41 else 42 li2_content = '<li><a href="#_label' + i + '">' 43 + $(h2_list[i]).text() + '</a></li>'; 44 content += li2_content; 45 } 46 content += '</ul>'; 47 content += '</div><p> </p>'; 48 /* content += '<p style="font-size:18px"><b>正文</b></p>'; */ 49 if ($('#cnblogs_post_body').length != 0) { 50 $($('#cnblogs_post_body')[0]).prepend(content); 51 } 52 } else { //当页面没有h2标签而有h3标签的时候:就去检索h3和h4 53 var h3_list = $('#cnblogs_post_body h3'); //获取h3 54 if (h3_list.length > 0) { 55 var content = '<a name="_labelTop"></a>'; 56 content += '<div id="navCategory">'; 57 content += '<p ><h2>自动生成的目录</h2></p>'; 58 content += '<ul>'; 59 for ( var i = 0; i < h3_list.length; i++) { 60 var go_to_top = '<div style="text-align: right"><a href="#_labelTop">回到顶部</a><a name="_label' + i + '"></a></div>'; 61 $(h3_list[i]).before(go_to_top); //在每一个h3以前添加回到顶部 62 63 var h4_list = $(h3_list[i]).nextAll("h4"); //获取每一个h3下面的h4 64 var li4_content = ''; 65 for ( var j = 0; j < h4_list.length; j++) { 66 var tmp = $(h4_list[j]).prevAll('h3').first(); 67 if (!tmp.is(h3_list[i])) 68 break; 69 var li4_anchor = '<a name="_label' + i + '_' + j + '"></a>'; //添加锚点 70 $(h4_list[j]).before(li4_anchor); 71 li4_content += '<li><a href="#_label' + i + '_' + j + '">' 72 + $(h4_list[j]).text() + '</a></li>'; //连接到锚点 73 } 74 75 var li3_content = ''; 76 if (li4_content.length > 0) 77 li3_content = '<li><a href="#_label' + i + '">' 78 + $(h3_list[i]).text() + '</a><ul>' 79 + li4_content + '</ul></li>'; 80 else 81 li3_content = '<li><a href="#_label' + i + '">' 82 + $(h3_list[i]).text() + '</a></li>'; 83 content += li3_content; 84 } 85 content += '</ul>'; 86 content += '</div><p> </p>'; 87 /* content += '<p style="font-size:18px"><b>正文</b></p>'; */ 88 if ($('#cnblogs_post_body').length != 0) { 89 $($('#cnblogs_post_body')[0]).prepend(content); 90 } 91 92 } 93 94 } 95 96 var qqinfo = '<p style="text-align:right;color:navy;font-size:12px">讨论QQ群:********</p>'; 97 $(mainContent[0]).prepend(qqinfo); 98 99 var title_h1 = $('#cnblogs_post_body h1');//将标题信息插入到开头 100 $(mainContent[0]).prepend(title_h1[0]); 101 } 102 103 GenerateContentList();//运行这个js函数 104 </script>