Markdown使用TOC自动生成导航栏
经常使用markdown 的玩家一定很想要一个自动生成的导航栏吧,自己写的基本思路就是
轮询监听滚动条的位置,通过抛锚和跳锚实现,这里介绍一下今天的主角,markdown-toc插件:
https://github.com/jonschlinkert/markdown-toc
# 0x00 安装
TOC = Table of content , 将内容制作成导航
这个插件是基于 nodejs 的,因此需要安装 node 和 npm ,这里同样采用nvm的形式安装
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.34.0/install.sh | bash
source ~/.bashrc
nvm list-remote
nvm install v10.16.0
node -v
安装好nvm后,就可以使用npm 安装插件了
npm install --save markdown-toc
# 0x01 命令行
经常使用markdown 的玩家一定很想要一个自动生成的导航栏吧,自己写的基本思路就是
轮询监听滚动条的位置,通过抛锚和跳锚实现,这里介绍一下今天的主角,markdown-toc插件:
这个插件带Cli命令,使用帮助如下
markdown-doc [选项] <输入>
<输入> 表示需要使用 TOC 的 markdown 文件,可以通过标准输入读取
[选项]
-i | 直接往 <输入> 的文件注入TOC标识符: <!-- toc -->,如果没有这个参数就输出到屏幕,不修改md文件 |
--json | 通过json格式打印TOC |
--append | 在字符串的后面追加TOC |
--bullets | 指定需要被生成TOC项的标识符号,可以指定多个: --bullets "*" --bullets "+" |
--maxdepth | TOC最大深度,就是可以折叠多少层,默认6层 |
--no-stripHeadingTags | 在强力功能前,不删去标题无关的HTML标签 |
# 0x02 亮点
经常使用markdown 的玩家一定很想要一个自动生成的导航栏吧,自己写的基本思路就是
轮询监听滚动条的位置,通过抛锚和跳锚实现,这里介绍一下今天的主角,markdown-toc插件:
特点:
1. 可根据自己的需求生成TOC模板
2. 对重复标题生效
3. 默认采用sane,也可以自己定制
4. 过滤器可以筛掉你不想要的标题
5. 导入期可以导入你想加入的标题
6. 可以使用强劲的函数来改变链接生成
7. 可作为 remarkable 的插件使用
很安全:
不会像其他TOC生成器一样,破坏前面的内容,或将前面的内容属性误认为标题
# 0x03 用法
经常使用markdown 的玩家一定很想要一个自动生成的导航栏吧,自己写的基本思路就是
轮询监听滚动条的位置,通过抛锚和跳锚实现,这里介绍一下今天的主角,markdown-toc插件:
var toc = require('markdown-toc'); toc('# One\n\n# Two').content;
// Results in:
// - [One](#one)
// - [Two](#two)
为了自定义输出,下面有几个属性将会返回
- content 自动生成导航导航的内容,你可以自定义样式
- highest 找到最高的等级标题,用于重新调整缩进
- tokens 可自定义的标题符号
# 0x04 API
1 - toc.plugin
作为 remarkable 插件使用,如下:
var Remarkable = require('remarkable');
var toc = require('markdown-toc'); function render(str, options) {
return new Remarkable()
.use(toc.plugin(options)) // <= register the plugin
.render(str);
}
使用实例
var results = render('# AAA\n# BBB\n# CCC\nfoo\nbar\nbaz');
2 - toc.json
可生成json格式的TOC对象
toc('# AAA\n## BBB\n### CCC\nfoo').json; // results in
[ { content: 'AAA', slug: 'aaa', lvl: 1 },
{ content: 'BBB', slug: 'bbb', lvl: 2 },
{ content: 'CCC', slug: 'ccc', lvl: 3 } ]
3 - toc.insert
在想插入TOC的位置写上 <!-- toc --> 或者 <!--toc--> 内容 <!--tocstop-->
(使用注释作为占位符可以避免破坏原本的代码)
<!-- toc -->
- old toc 1
- old toc 2
- old toc 3
<!-- tocstop --> ## abc
This is a b c. ## xyz
This is x y z.
结果是
<!-- toc -->
- [abc](#abc)
- [xyz](#xyz)
<!-- tocstop --> ## abc
This is a b c. ## xyz
This is x y z.
4 - 通用函数
为了方便给想定制TOC的用户folk一份,插件提供了一些通用函数
toc.bullets()
: 通过数组获取标题标记符toc.linkify()
: 链接到一个标题字符toc.slugify()
: 从标题字符中应用强力函数toc.strip()
: 从标题字符中去掉某些字符
例子
var result = toc('# AAA\n## BBB\n### CCC\nfoo');
var str = ''; result.json.forEach(function(heading) {
str += toc.linkify(heading.content);
});
# 0x05 选项
经常使用markdown 的玩家一定很想要一个自动生成的导航栏吧,自己写的基本思路就是
轮询监听滚动条的位置,通过抛锚和跳锚实现,这里介绍一下今天的主角,markdown-toc插件:
1 - 追加 (append)
追加一些字符串到匹配的标题标识符后面
toc(str, {append: '\n_(TOC generated by Verb)_'});
2 - 过滤 (filter)
类型: 函数
默认: undefined
参数:
str 命中的标题字符串
ele 标题记号对象
arr 所有的标题对象
过滤掉一些极端的匹配命中的标题,如下就是一个坏标题
[.aaa([foo], ...) another bad heading](#-aaa--foo--------another-bad-heading)
为了去除这种极端的情况,可以使用过滤器筛掉
function removeJunk(str, ele, arr) {
return str.indexOf('...') === -1;
} var result = toc(str, {filter: removeJunk});
//=> beautiful TOC
3 - 强劲(slugify)
类型: 函数
默认: 默认替换掉特殊符号
例子
var str = toc('# Some Article', {slugify: require('uslug')});
4 - 符号(bullet)
类型: 字符或者数组
默认: *
就是层叠的列表符号,传入数组 ['*', '-', '+']
5 - 首项 (first1)
类型:布尔
默认: true
排除文件中的第一个h1级标题。这样可以防止自述文件中的第一个标题出现在TOC中
6 - 最大深度 (first1)
类型: 数字
默认: 6
最大深度
6 - 去除头部标签(stripHeadingTags)
类型:布尔
默认: true
去除多余的标记,类似github 的 markdown 表现
Markdown使用TOC自动生成导航栏的更多相关文章
- css+js实现自动伸缩导航栏
用css+js实现自动伸缩导航栏 需要达到的效果: 默认首页选中样式 设置鼠标滑过效果:颜色变化(#f60),宽度变化,字体变化 所涉及的知识点: 布局:float css: 元素状态切换(displ ...
- AMScrollingNavbar框架(自动隐藏导航栏)使用简介
AMScrollingNavbar框架是一个可以上拉隐藏导航栏和下拉显示导航栏的框架,这个开源框架的调用也很简单,本章节就给大家介绍一下这个框架的用法. 一.下载及导入框架 AMScrollingNa ...
- 优于 swagger 的 java markdown 文档自动生成框架-01-入门使用
设计初衷 节约时间 Java 文档一直是一个大问题. 很多项目不写文档,即使写文档,对于开发人员来说也是非常痛苦的. 不写文档的缺点自不用多少,手动写文档的缺点也显而易见: 非常浪费时间,而且会出错. ...
- PHP 自动生成导航网址的最佳方法 v20130826
经常制作开发不同的网站的后台,写过很多种不同的后台导航写法. 最终积累了这种最写法,算是最好的吧.附上截图和代码如下(PHP+HTML) <?php $linkArr = array( 'ind ...
- 使用Python从Markdown文档中自动生成标题导航
概述 知识与思路 代码实现 概述 Markdown 很适合于技术写作,因为技术写作并不需要花哨的排版和内容, 只要内容生动而严谨,文笔朴实而优美. 为了编写对读者更友好的文章,有必要生成文章的标题导航 ...
- 第 10 篇:小细节 Markdown 文章自动生成目录,提升阅读体验
目录 在文中插入目录 在页面的任何地方插入目录 处理空目录 美化标题的锚点 URL 作者:HelloGitHub-追梦人物 文中涉及的示例代码,已同步更新到 HelloGitHub-Team 仓库 上 ...
- UIViewController的View显示在导航栏下面如何解决?
ios7之前的版本中UIViewController中的view在显示后会自动调整为去掉导航栏的高度的,控件会自动在导航栏以下摆放. 在iOS7中UIViewController的wantsFullS ...
- HTML&CSS基础学习笔记1.11—导航栏
上文我们介绍到的<a>标签,由于<a>标签可以用来跳转,所以我们可以拿<a>标签来生成网页的导航栏. 其实在实际运用中,<a>标签就经常会被用来生成导航 ...
- jquery tmpl生成导航
引入<script src="jquery.tmpl.min.js"></script> html<ul class="nav" ...
随机推荐
- centos7防火墙相关
selinux(保护文件安全) 安全增强型 Linux(Security-Enhanced Linux)简称 SELinux,它是一个 Linux 内核模块,也是 Linux 的一个安全子系统. SE ...
- Java数组复制、遍历、反转
/* 1.数组长度,直接length 即可! 2.min()/max(),需要调用库! 3.数组的复制 ,遍历复制,或者直接命名相等 即可! 4.数组反转时,直接折中即可!对调两重循环麻烦! */ i ...
- 对于vector中高效删除中间元素的技巧
众所周知,vector是连续存储空间,只提供高效的尾部删除方法pop_back() ,在中间删除的效率很低,那么如果大家想快速删除中间元素该如何实现? 话不多说,看代码: //移除vector元素,最 ...
- Week08_day01 (Hive开窗函数 row_number()的使用 (求出所有薪水前两名的部门))
数据准备: 7369,SMITH,CLERK,7902,1980-12-17,800,null,20 7499,ALLEN,SALESMAN,7698,1981-02-20,1600,300,30 7 ...
- 《流畅的Python》Object References, Mutability, and Recycling--第8章
Object References, Mutability, and Recycling 本章章节: Variables Are Not Boxes identity , Equality , Al ...
- 在vue项目中的main.js中直接使用element-ui中的Message 消息提示、MessageBox 弹框、Notification 通知
需求来源:向后台请求数据时后台挂掉了,后台响应就出现错误,不做处理界面就卡住了,这时需要在main.js中使用axios的响应拦截器在出现相应错误是给出提示.项目使用element-ui,就调用里面的 ...
- groovy http
import groovy.json.JsonOutput void api(){ def data = [jobId : "11111111111111", data : 5,s ...
- 冒泡排序之javascript
冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成.这个算法的名字 ...
- UVA323 Jury Compromise
思路:背包类DP 提交:3次 错因:没有注意得分的上下界导致 RE 显示 WA 题解: 我们很容易的想到把两种分数做一个差,来尽量背到 \(0\) . 那最大化总分呢?这时我们可以用两种分数的和作为物 ...
- sql 临时表的使用详解
Sqlserver数据库中的临时表详解 临时表在Sqlserver数据库中,是非常重要的,下面就详细介绍SQL数据库中临时表的特点及其使用,仅供参考. 临时表与永久表相似,但临时表存储在tem ...