文档章节

OSChina博客自动生成目录功能

爱你不行不行的
 爱你不行不行的
发布于 2016/05/22 21:22
字数 513
阅读 72
收藏 1

一、写在前面的话

这篇文章主要介绍博客自动生成目录的功能,以及怎么来生成漂亮的目录。

为什么要有目录呢?一篇很长的文章,有了目录后就可以定位到想看的位置。这是非常方便的!

1、自动生成目录原理

public static List<String> Anchor = new ArrayList<String>(){{
    add("h1");
    add("h2");
    add("h3");
    add("h4");
    add("h5");
    add("h6");
}};
  • 检测文章中的H标签,添加锚点
public String htmlAnchor(String html) {
    Document doc = Jsoup.parseBodyFragment(html);
    Elements anchors = doc.select("*");
    int i = 0;
    for(Element anchor : anchors){
        String tagName = anchor.tagName().toLowerCase();
        if(Anchor.contains(tagName) && anchor.hasText()) {
            i++;
            anchor.before("<span id='OSC_"+tagName+"_"+String.valueOf(i)+"'></span>");
        }
    }
    return doc.body().html();
}
  • 根据锚点,生成对应的目录
public String htmlContent(String html) {
    StringBuffer content = new StringBuffer();
    Document doc = Jsoup.parseBodyFragment(html);
    Elements anchors = doc.select("*");
    int i = 0;
    for(Element anchor : anchors) {
        String tagName = anchor.tagName().toLowerCase();
        if(Anchor.contains(tagName) && anchor.hasText()) {
            i++;
            content.append("<li class='osc_"+tagName+"'><a href='#OSC_"+tagName+"_"+String.valueOf(i)+"'>"+anchor.text()+"</a></li>");
        }
    }
    return content.toString();
}

2、写OSChina博客的时候怎么自动生成呢?

 

(1)、可视化编辑器
 

设置每一段落的小标题,如上图标题1、标题2、标题3...,也可以在html代码中使用h1、h2、h3...标签

(2)、MarkDown编辑器

markdown编辑器,只要在标题的前面添加“#”,标题(h1~h6)可使用相应个数的#来生成,如下

### this is a level-3 header ###

将生成 h3 标签

更多markdown语法 http://www.oschina.net/question/100267_75314

最后发表的时候别忘了把自动生成目录勾选为 是

3、怎么使生成的目录比较好看?

h1生成的目录是顶级目录,依次是h2、h3...

不同级别的标题使用不同的h标签,对应的markdown编辑器就是“#”号的个数,可视化编辑器就是“标题1”、“标题2”选项...

二、最后的话

返回到这篇博客的前面,目录是不是挺好看的呢

注:目前可视化编辑器和markdown编辑器只能生成到h5标签,h6无效, markdown预览的时候只到h3(预览由js解析,最终显示是由java解析的)。

© 著作权归作者所有

共有 人打赏支持
爱你不行不行的
粉丝 1
博文 4
码字总数 1571
作品 0
深圳
程序员
私信 提问

暂无文章

CentOS7 下安装 Nginx

1、添加Nginx存储库 要添加CentOS 7 EPEL仓库,请打开终端并使用以下命令 yum install epel-release 2、安装Nginx 现在Nginx存储库已经安装在您的服务器上,使用以下yum命令安装Nginx yum i...

Oo若离oO
7分钟前
0
0
漏洞防御与修复工作

漏洞管理工作是企业安全建设必不可少的一环,在风险管理工作中,漏洞管理能够防患于未然,企业对漏洞管理有着广泛的基础建设和实践经验。但随着攻防技术的发展,传统漏洞管理的安全技术和管理...

linuxprobe16
今天
1
0
MicroPython技术及应用前景

1 Micropython技术是什么? MicroPython极精简高效的实现了Python3语言。它包含Python标准库的一小部分,能在单片机和受限环境中运行。 1.1 MicroPython发展 由剑桥大学的理论物理学家乔治....

bodasisiter
今天
5
0
跟我学Spring Cloud(Finchley版)-13-通用方式使用Hystrix

本节详细讲解使用Hystrix的通用方式。 简介 Hystrix是由Netflix开源的一个延迟和容错库,用于隔离访问远程系统、服务或者第三方库,防止级联失败,从而提升系统的可用性与容错性。Hystrix主要...

周立_ITMuch
今天
2
0
🛠️Hanjst/汉吉斯特更新加JavaScript运行时优化等

这是 Hanjst/汉吉斯特 发布以来的首个主要升级更新版本。这次的主要升级更新的内容包括移除HTML Comments注释行, 优化在 Hanjst include模板文件时的JavaScript运行时环境。 Hanjst 在设计和...

wadelau
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部