zoukankan      html  css  js  c++  java
  • 2017.5.3 博客园自动生成章节目录

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

    1.效果图

    2.申请js权限

     写邮件给contact@cnblogs.com。

    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.写随笔时设置标题格式为-标题*

     就会自动生成目录了。

  • 相关阅读:
    什么是 rel="shortlink" ?
    HTML5 怎么兼容 XHTML
    Connection to `ssl://pecl.php.net:443' failed: mac系统
    记录小程序中经常犯的错误---在wxml中使用js方法(打脸不)
    从js对象数组中删除某一个对象
    彻底搞懂字符串提取方法 slice,substr,substring
    vue 项目中笔记-持续更新
    CF526G Spiders Evil Plan
    BZOJ2178 圆的面积并
    计算几何入门
  • 原文地址:https://www.cnblogs.com/lyh421/p/6803029.html
Copyright © 2011-2022 走看看