Project Icon

remark-gfm

支持GitHub风格Markdown的remark插件

remark-gfm是一个remark插件,为Markdown解析器添加GitHub Flavored Markdown (GFM)支持。它可解析和序列化自动链接、脚注、删除线、表格和任务列表等GFM特性。此插件适用于需要兼容GitHub文件和Gist的Markdown语法,并提供灵活配置选项满足不同需求。

remark-gfm

[![构建][build-badge]][build] [![覆盖率][coverage-badge]][coverage] ![下载量][downloads-badge] 大小 赞助商 支持者 聊天

remark 插件,用于支持 GFM(自动链接、脚注、删除线、表格、任务列表)。

目录

这是什么?

这个包是一个 unified (remark) 插件,用于启用 GitHub 通过 GFM 添加的 Markdown 扩展:自动链接(www.x.com)、脚注([^1])、删除线(~~stuff~~)、表格(| cell |…)和任务列表(* [x])。你可以使用这个插件来添加对解析和序列化这些扩展的支持。这些由 GitHub 对 CommonMark 的扩展被称为 GFM(GitHub Flavored Markdown)。

这个插件不处理 Markdown 如何转换为 HTML。那是由 remark-rehype 完成的。如果你的内容不是英文且使用了脚注,你应该配置该插件。在生成 HTML 时,你可能还想启用 rehype-slug 来为标题添加 id

另一个插件 remark-frontmatter 添加了对前置元数据的支持。GitHub 支持仓库和 Gist 中文件的 YAML 前置元数据,但它们并不将其视为 GFM 的一部分。

另一个插件 remark-github 添加了对 Markdown 在特定 GitHub 仓库的评论、问题、PR 和发布中如何工作的支持,通过链接引用提交、问题和用户。

还有一个插件 remark-breaks 将软换行(回车)转换为硬换行(<br>)。GitHub 在一些地方(评论、问题、PR 和发布)执行这种操作。

我应该在什么时候使用它?

当你想要支持 GitHub 在仓库文件、Gist 和其他几个地方所支持的相同功能时,这个项目很有用。用户经常认为其中一些扩展,特别是自动链接和表格,是普通 Markdown 的一部分,所以使用 remark-gfm 将有助于使你的实现与他们对 Markdown 的理解相匹配。在一些边缘情况下,GitHub 的实现以意想不到的方式工作,甚至与他们的规范描述不同,所以编写 GFM 并不总是最佳选择。

如果你只是想将 Markdown 转换为 HTML(可能带有一些扩展,如 GFM),我们推荐使用 micromarkmicromark-extension-gfm。如果你不使用插件并且想访问语法树,你可以使用 mdast-util-from-markdownmdast-util-gfm

安装

这个包只支持 ESM。在 Node.js(16+ 版本)中,使用 npm 安装:

npm install remark-gfm

在 Deno 中使用 esm.sh

import remarkGfm from 'https://esm.sh/remark-gfm@4'

在浏览器中使用 esm.sh

<script type="module">
  import remarkGfm from 'https://esm.sh/remark-gfm@4?bundle'
</script>

使用

假设我们的文档 example.md 包含:

# GFM

## 自动链接

www.example.com, https://example.com, 和 contact@example.com。

## 脚注

一个注释[^1]

[^1]: 大注释。

## 删除线

~一个~ 或 ~~两个~~ 波浪线。

## 表格

| a | b  |  c |  d  |
| - | :- | -: | :-: |

## 任务列表

* [ ] 待办
* [x] 已完成

...而我们的模块 example.js 包含:

import rehypeStringify from 'rehype-stringify'
import remarkGfm from 'remark-gfm'
import remarkParse from 'remark-parse'
import remarkRehype from 'remark-rehype'
import {read} from 'to-vfile'
import {unified} from 'unified'

const file = await unified()
  .use(remarkParse)
  .use(remarkGfm)
  .use(remarkRehype)
  .use(rehypeStringify)
  .process(await read('example.md'))

console.log(String(file))

...那么运行 node example.js 将产生:

<h1>GFM</h1>
<h2>自动链接</h2>
<p><a href="http://www.example.com">www.example.com</a>, <a href="https://example.com">https://example.com</a>, 和 <a href="mailto:contact@example.com">contact@example.com</a>。</p>
<h2>脚注</h2>
<p>一个注释<sup><a href="#user-content-fn-1" id="user-content-fnref-1" data-footnote-ref aria-describedby="footnote-label">1</a></sup></p>
<h2>删除线</h2>
<p><del>一个</del> 或 <del>两个</del> 波浪线。</p>
<h2>表格</h2>
<table>
<thead>
<tr>
<th>a</th>
<th align="left">b</th>
<th align="right">c</th>
<th align="center">d</th>
</tr>
</thead>
</table>
<h2>任务列表</h2>
<ul class="contains-task-list">
<li class="task-list-item"><input type="checkbox" disabled> 待办</li>
<li class="task-list-item"><input type="checkbox" checked disabled> 已完成</li>
</ul>
<section data-footnotes class="footnotes"><h2 class="sr-only" id="footnote-label">脚注</h2>
<ol>
<li id="user-content-fn-1">
<p>大注释。 <a href="#user-content-fnref-1" data-footnote-backref class="data-footnote-backref" aria-label="返回内容">↩</a></p>
</li>
</ol>
</section>

API

这个包不导出任何标识符。默认导出是 remarkGfm

unified().use(remarkGfm[, options])

添加对 GFM(自动链接、脚注、删除线、表格、任务列表)的支持。

参数
  • options (Options, 可选) — 配置
返回值

无 (undefined)。

Options

配置(TypeScript 类型)。

字段
  • stringLength (((value: string) => number), 默认值: d => d.length) — 检测表格单元格的大小,用于对齐单元格
  • singleTilde (boolean, 默认值: true) — 是否支持单个波浪线的删除线; 单个波浪线在 github.com 上有效,但在技术上被 GFM 禁止; 你始终可以使用 2 个或更多波浪线进行删除线
  • tablePipeAlign (boolean, 默认值: true) — 是否对齐表格管道符
  • tableCellPadding (boolean, 默认值: true) — 是否在表格管道符和单元格之间添加一个空格作为填充

示例

示例:singleTilde

要关闭对单波浪线解析删除线的支持,传入 singleTilde: false

// …

const file = await unified()
  .use(remarkParse)
  .use(remarkGfm, {singleTilde: false})
  .use(remarkRehype)
  .use(rehypeStringify)
  .process('~one~ and ~~two~~')

console.log(String(file))

生成结果:

<p>~one~ and <del>two</del></p>

示例:stringLength

可以根据单元格的视觉宽度对表格进行对齐。 首先,让我们展示问题所在:

import {remark} from 'remark'
import remarkGfm from 'remark-gfm'

const input = `| Alpha | Bravo |
| - | - |
| 中文 | Charlie |
| 👩‍❤️‍👩 | Delta |`

const file = await remark().use(remarkGfm).process(input)

console.log(String(file))

上面的代码展示了如何使用 remark 来格式化 markdown。 输出结果如下:

| Alpha    | Bravo   |
| -------- | ------- |
| 中文       | Charlie |
| 👩‍❤️‍👩 | Delta   |

为了改善这些全角字符和表情符号的对齐,传入一个计算单元格视觉宽度的 stringLength 函数。 一种这样的算法是 string-width。 它可以这样使用:

@@ -1,5 +1,6 @@
 import {remark} from 'remark'
 import remarkGfm from 'remark-gfm'
+import stringWidth from 'string-width'

@@ -10,7 +11,7 @@ async function main() {
 | 👩‍❤️‍👩 | Delta |`

-const file = await remark().use(remarkGfm).process(input)
+const file = await remark()
+  .use(remarkGfm, {stringLength: stringWidth})
+  .process(input)

   console.log(String(file))

进行这些更改后,我们代码的输出如下:

| Alpha | Bravo   |
| ----- | ------- |
| 中文  | Charlie |
| 👩‍❤️‍👩    | Delta   |

错误

关于 GFM 中存在但这里不存在的错误,或其他支持的特殊情况,请参阅每个相应的自述文件:

编写

关于如何编写 GFM 的建议,请参阅每个相应的自述文件:

HTML

此插件不处理 markdown 如何转换为 HTML。 关于如何实现以及如何更改,请参阅 remark-rehype

CSS

关于 GitHub 如何对这些功能进行样式设置的信息,请参阅每个相应的自述文件:

语法

关于这些功能的语法信息,请参阅每个相应的自述文件:

语法树

关于这些功能的语法树信息,请参阅每个相应的自述文件:

类型

此包使用 TypeScript 进行完全类型化。 它导出了额外的类型 Options

默认情况下,@types/mdast 支持节点类型。

兼容性

unified 集体维护的项目与维护版本的 Node.js 兼容。

当我们发布新的主要版本时,我们会放弃对不再维护的 Node.js 版本的支持。 这意味着我们尽量保持当前发布线 remark-gfm@^4 与 Node.js 16 兼容。

此插件适用于 remark-parse 11+ 版本(remark 15+ 版本)。 之前的版本(v3)适用于 remark-parse 10 版本(remark 14 版本)。 在此之前,v2 适用于 remark-parse 9 版本(remark 13 版本)。 remark-parseremark 的早期版本有一个默认为 true 的 gfm 选项,启用了此功能。

安全

使用 remark-frontmatter 不涉及 rehypehast)或用户内容,因此不存在 跨站脚本攻击(XSS) 的漏洞。

相关

贡献

查看 remarkjs/.github 中的 contributing.md 以了解参与方式。 查看 support.md 以获取帮助的方法。

本项目有一个 行为准则。 通过与此仓库、组织或社区进行交互,您同意遵守其条款。

许可证

MIT © Titus Wormer [downloads-badge]: https://img.shields.io/npm/dm/remark-gfm.svg

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号