今天在迁移博客项目的时候,发现原来在 hugo 中可以使用的 Emoji 和 tasks 功能都不能正常使用了,查询了一下原因,主要是因为 hexo 默认的解析器是 hexo-renderer-marked
,这个默认的渲染器是不支持 emoji 功能的,但是支持 tasks,但是这个渲染器是不支持扩展的,所以如果希望同时使用这两个功能的话,就需要换一个渲染器。
这里推荐的是 hexo-renderer-markdown-it
渲染器,支持扩展,采用的是 markdown-it
的内核来解析 markdown 的文本。
npm un hexo-renderer-marked -S
npm i hexo-renderer-markdown-it -S
这样就替换完成了,然后再安装需要的插件:
npm i markdown-it-emoji markdown-it-task-lists -S
然后再增加相关配置:
markdown:
render:
html: true # 在 markdown 文本中支持 html tag 标签
xhtmlOut: false # 需要 xtml 文档,使用 <br /> 替代 <br>
breaks: true # 用 <br> 开始新的一行
linkify: true # 自动将 可能是链接的内容转换成链接
typographer: true # 印刷标识转换
plugins:
- markdown-it-abbr
- markdown-it-footnote
- markdown-it-ins
- markdown-it-sub
- markdown-it-sup
- markdown-it-emoji
- markdown-it-task-lists
anchors:
level: 2
collisionSuffix: ''
permalink: false,
permalinkClass: 'header-anchor'
permalinkSymbol: ''
case: 0
separator: ''
typographer 解释:
将 (c) (C) (r) (R) (tm) (TM) (p) (P) +-
这些标识转换成 © © ® ® ™ ™ § § ± 。
一些常用的插件,比如上标和下标,可以在插件里加上 markdown-it-sub
和 markdown-it-sup
,可以直接用 19^th^
19th 还有 H~2~O
表示 H2O 。
还有脚本、定义列表等功能,具体的见 https://markdown-it.github.io/ 。
因为 markdown-it 是支持扩展的,所以怎么找对应的扩展,也是非常重要的功能,比如 tasks 的支持,可以到 https://www.npmjs.com/ 里进行搜索,关键字是 keywords:markdown-it-plugin
或者直接打开链接 https://www.npmjs.com/search?q=keywords:markdown-it-plugin 。
就可以按照对应的功能去找寻找插件了。