Skip to content

HTML

Overview

The HTML block allows a user to wrap Markdown in arbitrary HTML elements.

By default, the meta-plugin is registered when pymdownx.blocks is registered, but if you were customizing which meta-plugins get loaded, you can do so by doing the following:

import markdown
from pymdownx.blocks.html import HTML
md = markdown.Markdown(extensions=['pymdownx.blocks.html'])

Usage

Generally, HTML blocks can be defined simply by specifying the html generic block type followed by the tag name.

HTML
/// html | div
some *markdown* content
///

some markdown content

Classes and IDs and arbitrary attributes can be specified by using selector-like notation:

  • div.my-class will add a class of name my-class to a tag of name div.
  • div#some-id will add an ID of name some-id to a tag of name div.
  • div[attr] will add an attribute of name attr to a tag of name div. You can also add values (div[attr=value]), quoted values (div[attr="quoted value"]), and even multiple values (div[attr1=value attr2="quoted value"]).
  • Attributes can also be chained: div#some-id.class[attr=value].
HTML
/// html | div[style='border: 1px solid red;']
some *markdown* content
///

some markdown content

By default HTML blocks will automatically have the content rendering determined from tag name, so div blocks will be treated as block elements, span will be treated as inline elements, and things like pre will treat the content as raw text that needs HTML escaping, and things like script will be treated as raw content does not need HTML escaping. With that said, there may be cases where an HTML element isn't properly recognized yet, or the user simply wants to control how the element processes its content, in these cases, the markdown option can be used to specify how Markdown content is handled.

Markdown Modes Description
block Parsed block content will be handled by the Markdown parser as content under a block element.
inline Parsed block content will be handled by the Markdown parser as content under an inline element.
raw Parsed block content will be preserved. No additional Markdown parsing will be applied. Content will be HTML escaped to preserve the content as is.
auto Depending on whether the wrapping parent is a block element, inline element, or something like a code element, Blocks will choose the best approach for the content. Decision is made based on the element returned by the on_add event.
html Like raw, content will be preserved, but the content will not be HTML escaped and will be passed through as unmodified HTML. Any required sanitizing should be provided by the user post Markdown processing.

Raw and HTML Mode

When using raw tags or forcing raw mode with markdown: raw (HTML escaped) or markdown: html (no HTML escaping), code must be indented. This is because Python Markdown will look for and process raw HTML in non indented blocks. The only avoid this is to use indented code blocks. If content is not indented, the content may be missing at the end.

Recognized raw block tags: canvas, math, option, pre, and textarea.

Recognized raw HTML tags: script and style.

Also, make sure to have a new line before indented content so it is not recognized as an attempt to specify YAML options.

In the following example we force pre to handle content as Markdown block content instead of the usual raw content default.

Pre as Block
/// html | pre

    some *markdown* content
///

/// html | pre
    markdown: block

some *markdown* content
///
some *markdown* content

some markdown content

Custom Tag Handling

It is possible that in the future new tags could be added to the HTML spec, and it is also possible that the extension may not recognize such tags for some length of time. While such tags can be added in future releases, the HTML extension allows for users to specify such tags to navigate around such issues, or even make up their own tags.

To teach the HTML extension about unknown tags, simply use the custom option to specify a tag name and the assumed default mode.

import markdown
from pymdownx.blocks.html import HTML
extensions = ['pymdownx.blocks.html']
extension_configs = {
    'pymdown.blocks.html': {
        'custom': [
            {'tag': 'sometag', 'mode': 'block'}
        ]
    }
}
md = markdown.Markdown(extensions=extensions, extension_configs=extension_configs)

Then you can use your custom tag knowing it will be handled properly.

/// html | sometag

Some block content.

- List item A.

- List item B.
///

Global Options

Options Type Descriptions
custom [dictionary] Specify custom tags with assumed default handling.

Per Block Options

Options Type Descriptions
markdown string String value to control how Markdown content is processed. Valid options are: auto, block, inline, html, and raw.
attrs dictionary A dictionary that defines attributes for the outer, wrapper element.