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 | 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 namemy-class
to a tag of namediv
.div#some-id
will add an ID of namesome-id
to a tag of namediv
.div[attr]
will add an attribute of nameattr
to a tag of namediv
. 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 | 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.
/// 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. |