markdown-it vs react-markdown
Markdown 解析库
markdown-itreact-markdown类似的npm包:

Markdown 解析库

Markdown 解析库用于将 Markdown 格式的文本转换为 HTML,方便在网页中展示格式化的内容。这些库提供了灵活的解析选项和扩展功能,使开发者能够根据需求自定义 Markdown 的解析方式。选择合适的 Markdown 解析库可以提高开发效率,并确保生成的 HTML 代码符合项目的需求。

npm下载趋势

3 年

GitHub Stars 排名

统计详情

npm包名称
下载量
Stars
大小
Issues
发布时间
License
markdown-it021,257768 kB592 个月前MIT
react-markdown015,60552.6 kB31 年前MIT

功能对比: markdown-it vs react-markdown

性能

  • markdown-it:

    markdown-it 是一个高性能的 Markdown 解析器,使用纯 JavaScript 编写,能够快速处理大量文本。它的设计目标是提供快速的解析速度,适合需要实时渲染的应用场景。

  • react-markdown:

    react-markdown 主要依赖于 React 的渲染机制,因此性能与 React 的渲染效率密切相关。对于小型 Markdown 文本的渲染,性能表现良好,但在处理大量文本时,可能需要优化组件的渲染策略。

扩展性

  • markdown-it:

    markdown-it 提供了丰富的插件机制,允许开发者根据需求扩展解析功能。你可以轻松添加自定义规则、语法和渲染选项,满足特定的项目需求。

  • react-markdown:

    react-markdown 允许通过组件化的方式扩展功能,支持自定义渲染器和组件。虽然扩展性不如 markdown-it 灵活,但对于大多数常见需求来说已经足够。

学习曲线

  • markdown-it:

    markdown-it 的学习曲线相对平缓,文档清晰,易于上手。对于需要自定义解析的开发者,理解其插件机制可能需要一些时间,但整体上较为简单。

  • react-markdown:

    react-markdown 的学习曲线也较为平滑,尤其是对于已经熟悉 React 的开发者。它的 API 简单明了,能够快速集成到现有的 React 项目中。

社区支持

  • markdown-it:

    markdown-it 拥有活跃的社区和丰富的插件生态,开发者可以找到大量的资源和示例,方便解决问题和获取灵感。

  • react-markdown:

    react-markdown 作为 React 生态的一部分,享有良好的社区支持,开发者可以轻松找到相关的文档和示例,快速上手和解决问题。

使用场景

  • markdown-it:

    markdown-it 适合需要高度自定义和复杂解析的场景,例如博客平台、文档生成工具等,能够处理多种 Markdown 扩展和自定义语法。

  • react-markdown:

    react-markdown 更适合在 React 应用中快速渲染 Markdown 内容,适用于简单的内容展示,如评论区、文档说明等,能够快速集成和使用。

如何选择: markdown-it vs react-markdown

  • markdown-it:

    选择 markdown-it 如果你需要一个快速、可扩展的 Markdown 解析器,支持插件和自定义规则,适合需要复杂解析的场景。它具有良好的性能和灵活性,适合需要高度定制化的项目。

  • react-markdown:

    选择 react-markdown 如果你正在使用 React 框架,并希望轻松将 Markdown 内容渲染为 React 组件。它提供了简单的 API 和良好的集成,适合快速开发和简单的 Markdown 渲染需求。

markdown-it的README

markdown-it

CI NPM version Coverage Status Gitter

Markdown parser done right. Fast and easy to extend.

Live demo

  • Follows the CommonMark spec + adds syntax extensions & sugar (URL autolinking, typographer).
  • Configurable syntax! You can add new rules and even replace existing ones.
  • High speed.
  • Safe by default.
  • Community-written plugins and other packages on npm.

Table of content

Install

node.js:

npm install markdown-it

browser (CDN):

Usage examples

See also:

Simple

// node.js
// can use `require('markdown-it')` for CJS
import markdownit from 'markdown-it'
const md = markdownit()
const result = md.render('# markdown-it rulezz!');

// browser with UMD build, added to "window" on script load
// Note, there is no dash in "markdownit".
const md = window.markdownit();
const result = md.render('# markdown-it rulezz!');

Single line rendering, without paragraph wrap:

import markdownit from 'markdown-it'
const md = markdownit()
const result = md.renderInline('__markdown-it__ rulezz!');

Init with presets and options

(*) presets define combinations of active rules and options. Can be "commonmark", "zero" or "default" (if skipped). See API docs for more details.

import markdownit from 'markdown-it'

// commonmark mode
const md = markdownit('commonmark')

// default mode
const md = markdownit()

// enable everything
const md = markdownit({
  html: true,
  linkify: true,
  typographer: true
})

// full options list (defaults)
const md = markdownit({
  // Enable HTML tags in source
  html:         false,

  // Use '/' to close single tags (<br />).
  // This is only for full CommonMark compatibility.
  xhtmlOut:     false,

  // Convert '\n' in paragraphs into <br>
  breaks:       false,

  // CSS language prefix for fenced blocks. Can be
  // useful for external highlighters.
  langPrefix:   'language-',

  // Autoconvert URL-like text to links
  linkify:      false,

  // Enable some language-neutral replacement + quotes beautification
  // For the full list of replacements, see https://github.com/markdown-it/markdown-it/blob/master/lib/rules_core/replacements.mjs
  typographer:  false,

  // Double + single quotes replacement pairs, when typographer enabled,
  // and smartquotes on. Could be either a String or an Array.
  //
  // For example, you can use '«»„“' for Russian, '„“‚‘' for German,
  // and ['«\xA0', '\xA0»', '‹\xA0', '\xA0›'] for French (including nbsp).
  quotes: '“”‘’',

  // Highlighter function. Should return escaped HTML,
  // or '' if the source string is not changed and should be escaped externally.
  // If result starts with <pre... internal wrapper is skipped.
  highlight: function (/*str, lang*/) { return ''; }
});

Plugins load

import markdownit from 'markdown-it'

const md = markdownit
  .use(plugin1)
  .use(plugin2, opts, ...)
  .use(plugin3);

Syntax highlighting

Apply syntax highlighting to fenced code blocks with the highlight option:

import markdownit from 'markdown-it'
import hljs from 'highlight.js' // https://highlightjs.org

// Actual default values
const md = markdownit({
  highlight: function (str, lang) {
    if (lang && hljs.getLanguage(lang)) {
      try {
        return hljs.highlight(str, { language: lang }).value;
      } catch (__) {}
    }

    return ''; // use external default escaping
  }
});

Or with full wrapper override (if you need assign class to <pre> or <code>):

import markdownit from 'markdown-it'
import hljs from 'highlight.js' // https://highlightjs.org

// Actual default values
const md = markdownit({
  highlight: function (str, lang) {
    if (lang && hljs.getLanguage(lang)) {
      try {
        return '<pre><code class="hljs">' +
               hljs.highlight(str, { language: lang, ignoreIllegals: true }).value +
               '</code></pre>';
      } catch (__) {}
    }

    return '<pre><code class="hljs">' + md.utils.escapeHtml(str) + '</code></pre>';
  }
});

Linkify

linkify: true uses linkify-it. To configure linkify-it, access the linkify instance through md.linkify:

md.linkify.set({ fuzzyEmail: false });  // disables converting email to link

API

API documentation

If you are going to write plugins, please take a look at Development info.

Syntax extensions

Embedded (enabled by default):

Via plugins:

Manage rules

By default all rules are enabled, but can be restricted by options. On plugin load all its rules are enabled automatically.

import markdownit from 'markdown-it'

// Activate/deactivate rules, with currying
const md = markdownit()
  .disable(['link', 'image'])
  .enable(['link'])
  .enable('image');

// Enable everything
const md = markdownit({
  html: true,
  linkify: true,
  typographer: true,
});

You can find all rules in sources:

Benchmark

Here is the result of readme parse at MB Pro Retina 2013 (2.4 GHz):

npm run benchmark-deps
benchmark/benchmark.mjs readme

Selected samples: (1 of 28)
 > README

Sample: README.md (7774 bytes)
 > commonmark-reference x 1,222 ops/sec ±0.96% (97 runs sampled)
 > current x 743 ops/sec ±0.84% (97 runs sampled)
 > current-commonmark x 1,568 ops/sec ±0.84% (98 runs sampled)
 > marked x 1,587 ops/sec ±4.31% (93 runs sampled)

Note. CommonMark version runs with simplified link normalizers for more "honest" compare. Difference is ≈1.5×.

As you can see, markdown-it doesn't pay with speed for its flexibility. Slowdown of "full" version caused by additional features not available in other implementations.

markdown-it for enterprise

Available as part of the Tidelift Subscription.

The maintainers of markdown-it and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use. Learn more.

Authors

markdown-it is the result of the decision of the authors who contributed to 99% of the Remarkable code to move to a project with the same authorship but new leadership (Vitaly and Alex). It's not a fork.

References / Thanks

Big thanks to John MacFarlane for his work on the CommonMark spec and reference implementations. His work saved us a lot of time during this project's development.

Related Links:

Ports