markdown-to-jsx
Markdown Component for React, Preact + Friends.
markdown-to-jsx
uses a fork of simple-markdown as its parsing engine and extends it in a number of ways to make your life easier. Notably, this package offers the following additional benefits:
-
Arbitrary HTML is supported and parsed into the appropriate JSX representation
withoutdangerouslySetInnerHTML
-
Any HTML tags rendered by the compiler and/or
<Markdown>
component can be overridden to include additional
props or even a different HTML representation entirely. -
GFM task list support.
-
Fenced code blocks with highlight.js support.
All this clocks in at around 5 kB gzipped, which is a fraction of the size of most other React markdown components.
Requires React >= 0.14.
Installation
Usage
markdown-to-jsx
exports a React component by default for easy JSX composition:
ES6-style usage*:
* NOTE: JSX does not natively preserve newlines in multiline text. In general, writing markdown directly in JSX is discouraged and it's a better idea to keep your content in separate .md files and require them, perhaps using webpack's raw-loader.
Parsing Options
options.forceBlock
By default, the compiler will try to make an intelligent guess about the content passed and wrap it in a <div>
, <p>
, or <span>
as needed to satisfy the "inline"-ness of the markdown. For instance, this string would be considered "inline":
But this string would be considered "block" due to the existence of a header tag, which is a block-level HTML element:
However, if you really want all input strings to be treated as "block" layout, simply pass options.forceBlock = true
like this:
options.forceInline
The inverse is also available by passing options.forceInline = true
:
options.overrides - Override Any HTML Tag's Representation
Pass the options.overrides
prop to the compiler or <Markdown>
component to seamlessly revise the rendered representation of any HTML tag. You can choose to change the component itself, add/change props, or both.
If you only wish to provide a component override, a simplified syntax is available:
Depending on the type of element, there are some props that must be preserved to ensure the markdown is converted as intended. They are:
a
:title
,href
img
:title
,alt
,src
input[type="checkbox"]
:checked
,readonly
(specifically, the one rendered by a GFM task list)ol
:start
td
:style
th
:style
Any conflicts between passed props
and the specific properties above will be resolved in favor of markdown-to-jsx
's code.
options.overrides - Rendering Arbitrary React Components
One of the most interesting use cases enabled by the HTML syntax processing in markdown-to-jsx
is the ability to use any kind of element, even ones that aren't real HTML tags like React component classes.
By adding an override for the components you plan to use in markdown documents, it's possible to dynamically render almost anything. One possible scenario could be writing documentation:
markdown-to-jsx
also handles JSX interpolation syntax, but in a minimal way to not introduce a potential attack vector. Interpolations are sent to the component as their raw string, which the consumer can then eval()
or process as desired to their security needs.
In the following case, DatePicker
could simply run parseInt()
on the passed startTime
for example:
Another possibility is to use something like recompose's withProps()
HOC to create various pregenerated scenarios and then reference them by name in the markdown:
options.createElement - Custom React.createElement behavior
Sometimes, you might want to override the React.createElement
default behavior to hook into the rendering process before the JSX gets rendered. This might be useful to add extra children or modify some props based on runtime conditions. The function mirrors the React.createElement
function, so the params are type, [props], [...children]
:
Getting the smallest possible bundle size
Many development conveniences are placed behind process.env.NODE_ENV !== "production"
conditionals. When bundling your app, it's a good idea to replace these code snippets such that a minifier (like uglify) can sweep them away and leave a smaller overall bundle.
Here are instructions for some of the popular bundlers:
Usage with Preact
Everything will work just fine! Simply Alias react
to preact-compat
like you probably already are doing.
Using The Compiler Directly
If desired, the compiler function is a "named" export on the markdown-to-jsx
module:
It accepts the following arguments: