zoukankan      html  css  js  c++  java
  • 博客园随笔如何自动生成目录(原理:页脚js函数且执行)

    博客园随笔如何自动生成目录(原理:页脚js函数且执行)

    一、总结

    一句话总结:用的是jquery的dom操作知识,主要操作就是在标题那里添加锚点,然后在目录那里链接到锚点

    1、如何在标题前面添加锚点?

    用before方法

     30                     var li3_anchor = '<a name="_label' + i + '_' + j + '"></a>'; //添加锚点
     31                     $(h3_list[j]).before(li3_anchor);

    2、如何在目录那里链接到锚点?

    a标签的href属性到锚点a标签的name属性

     32                     li3_content += '<li><a href="#_label' + i + '_' + j + '">'
     33                             + $(h3_list[j]).text() + '</a></li>'; //链接到锚点

    3、将标题插入到开头用的什么方法?

    prepend内部之前插入方法

     99         var title_h1 = $('#cnblogs_post_body h1');//将标题信息插入到开头
    100         $(mainContent[0]).prepend(title_h1[0]);

    实现原理:在页脚添加了一个js函数,然后调用执行,用了很多类选择器和dom里面的知识, 里面有jquery

    二、让博客园博客自动生成章节目录索引

    对于比较长的文章,有一个好的目录索引是很有必要的,可以让读者比较清楚地了解文章内容和层次。然而,目前(2015.7)博客园不像csdn博客那样,会对发布的文章自动生成目录索引。不过,一些网友通过博客园后台提供的一些自定义功能,自己写脚本实现了这一功能。我用的脚本主要就是参考@薰衣草的旋律 的,文章地址是:http://www.cnblogs.com/wangqiguo/p/4355032.html。

    原作者的脚本只支持1级目录,我改了两级:第1级是h2,第2级是h3。还添加了一些小玩意,比如讨论qq群号。效果如下图所示:

    添加功能的具体步骤是:

      1. 确保自己的博客园后台支持js
        这个默认是不支持,需要向官方发个邮件申请开通(邮箱是contact@cnblogs.com),我简单写了封邮件,1小时就回复了,邮件内容我只写了两个字:如题。。。。
      2. 到后台加入脚本
        打开博客园后台,进入“设置”标签页,在最下面的“页脚Html代码”对应的编辑框粘贴你的js代码,然后点“保存”按钮保存。
      3. 按格式写文章
        在写新博文的时候,注意按照你js脚本里设定的格式来划分章节,比如h2,h3等。当然,以前发布的文章如果有h2,h3之类,也会自动生成目录索引。

    脚本如下:

     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

    参考:

    让博客园博客自动生成章节目录索引 - 赵子清 - 博客园
    https://www.cnblogs.com/zzqcn/p/4657124.html

    三、自己的目录

    修改了一下上面的代码

    • 优化了一下格式,
    • 并且功能修改为在有h2的时候目录结构为h2和h3,没有h2的时候目录结构为h3和h4,
    • 也把标题放到了目录之前
    • 也增加了一些代码注释
      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>&nbsp;</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>&nbsp;</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>
  • 相关阅读:
    每日一题
    每日一题
    mysql 约束
    七种基础排序算法代码总汇
    netty之bytebuf粘包、分包
    Java nio 简易练手版 模拟用户群聊
    Java网络编程之终端聊天菜鸟版
    双重检测优化与加锁操作redis
    centos部署smb服务
    从事 iOS 研发6年的面经——送给准备跳槽的你!
  • 原文地址:https://www.cnblogs.com/Renyi-Fan/p/9094807.html
Copyright © 2011-2022 走看看