markdown-it vs showdown vs remarkable
Markdown パーサーライブラリ
markdown-itshowdownremarkable類似パッケージ:
Markdown パーサーライブラリ

Markdown パーサーライブラリは、Markdown 形式のテキストを HTML に変換するためのツールです。これらのライブラリは、開発者が Markdown を簡単に扱えるようにし、コンテンツの表示を効率化します。これにより、ユーザーはリッチなテキストを簡単に作成し、ウェブアプリケーションやブログに統合することができます。

npmのダウンロードトレンド
3 年
GitHub Starsランキング
統計詳細
パッケージ
ダウンロード数
Stars
サイズ
Issues
公開日時
ライセンス
markdown-it12,437,52620,782767 kB552年前MIT
showdown1,088,88814,778801 kB227-MIT
remarkable991,2595,822-1326年前MIT
機能比較: markdown-it vs showdown vs remarkable

拡張性

  • markdown-it:

    Markdown-it は、プラグインを通じて機能を拡張できるため、特定のニーズに合わせたカスタマイズが可能です。独自のプラグインを作成することもでき、柔軟性が高いです。

  • showdown:

    Showdown もプラグインをサポートしていますが、他のライブラリに比べて拡張性はやや劣ります。それでも、基本的な機能を提供し、簡単にカスタマイズできます。

  • remarkable:

    Remarkable は、基本的な機能に焦点を当てており、拡張性は限定的ですが、シンプルな使用法が魅力です。必要最低限の機能を提供するため、特定の拡張が不要な場合に適しています。

パフォーマンス

  • markdown-it:

    Markdown-it は、高速なパフォーマンスを誇り、大規模な文書を処理する際にもスムーズです。特に、複雑な Markdown を扱う場合でも、効率的に変換を行います。

  • showdown:

    Showdown のパフォーマンスは良好ですが、特に大規模なデータセットを扱う場合には、他のライブラリと比較して若干劣ることがあります。

  • remarkable:

    Remarkable は、軽量で高速な変換を提供します。パフォーマンスが重視されるプロジェクトにおいて、迅速な処理が求められる場合に最適です。

学習曲線

  • markdown-it:

    Markdown-it は、豊富な機能を持っているため、最初は学習曲線がやや急ですが、慣れると非常に強力なツールになります。

  • showdown:

    Showdown は、非常に直感的なインターフェースを持っており、すぐに使い始めることができるため、学習曲線は非常に緩やかです。

  • remarkable:

    Remarkable は、シンプルな API を提供しているため、学習曲線が緩やかで、初心者でもすぐに使い始めることができます。

サポートされる機能

  • markdown-it:

    Markdown-it は、GitHub Flavored Markdown (GFM) を含む多くの Markdown 機能をサポートしています。これにより、一般的な Markdown の使用に加え、特定の機能を簡単に利用できます。

  • showdown:

    Showdown は、基本的な Markdown 機能をサポートしており、特にシンプルな変換を必要とする場合に適しています。

  • remarkable:

    Remarkable は、基本的な Markdown 機能に加え、シンプルな拡張機能を提供していますが、特定の高度な機能はサポートしていません。

使用シナリオ

  • markdown-it:

    Markdown-it は、ブログやドキュメントエディタなど、複雑な Markdown 機能を必要とするアプリケーションに最適です。

  • showdown:

    Showdown は、クライアントサイドとサーバーサイドの両方で使用できるため、ウェブアプリケーション全般に適しています。

  • remarkable:

    Remarkable は、パフォーマンスが重要なアプリケーションや、シンプルな Markdown の変換が求められるプロジェクトに向いています。

選び方: markdown-it vs showdown vs remarkable
  • markdown-it:

    Markdown-it はプラグインのサポートが豊富で、カスタマイズ性が高いです。特に、拡張機能を必要とするプロジェクトや、特定の Markdown 機能を追加したい場合に適しています。

  • showdown:

    Showdown は、ブラウザと Node.js の両方で動作するため、クライアントサイドとサーバーサイドの両方で使用する必要がある場合に適しています。また、シンプルな設定で始められるため、初心者にも扱いやすいです。

  • remarkable:

    Remarkable はパフォーマンスが高く、シンプルな 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