Markdown Installed
Create pages in Markdown format
Description
Markdown is a popular markup language for writing content that is converted to HTML. It is useful for pages with long text like posts, articles, or documentation sites.
Installation
This plugin is installed by default. 🎉
Configuration
If you want to change the default configuration, use the second argument of lume()
function in your _config.ts
file. See all available options in Deno Doc.
import lume from "lume/mod.ts";
// Markdown plugin configuration
const markdown = {};
const site = lume({}, { markdown });
export default site;
Use the options
property to change the markdown-it settings:
// Change markdown-it configuration
const markdown = {
options: {
breaks: false,
xhtmlOut: true,
},
};
const site = lume({}, { markdown });
Additionally, you can use hooks to add additional plugins and rules.
Plugins
Lume uses markdown-it as the markdown parser, with the following plugins enabled:
- markdown-it-deflist to add support for definition lists (
<dl>
tag). - markdown-it-attrs to add support for CSS classes and other attributes using
{}
.
You can find more plugins in NPM that you can use with the plugins
option. For example, to add the markdown-it-emoji plugin:
import emoji from "npm:markdown-it-emoji";
// Set the markdown plugins
const markdown = {
plugins: [emoji],
keepDefaultPlugins: true,
};
const site = lume({}, { markdown });
The keepDefaultPlugins
option keeps the two default plugins installed by default by Lume (markdown-it-deflist
and markdown-it-attrs
). Set it to false
(or don't set it at all) to replace the defaults with your specified plugins.
You can pass options to your markdown-it plugins using an array with [plugin, options]
signature. Example:
import anchor from "npm:markdown-it-anchor";
import footnote from "npm:markdown-it-footnote";
// Pass options to markdown-it plugins
const markdown = {
plugins: [[anchor, { level: 2 }], footnote],
keepDefaultPlugins: true,
};
const site = lume({}, { markdown });
Lume markdown plugins
The repository lume_markdown_plugins contain a collection of plugins specially adapted to Lume, with useful features like extract the title from the markdown or generate a table of contents.
Hooks
This plugin exposes the following hooks:
addMarkdownItPlugin(plugin, options)
To add additional plugins.addMarkdownItRule(name, rule)
To add additional rules.
import lume from "lume/mod.ts";
import anchor from "npm:markdown-it-anchor";
import footnote from "npm:markdown-it-footnote";
const site = lume();
site.hooks.addMarkdownItPlugin(anchor, { level: 2 });
site.hooks.addMarkdownItPlugin(footnote);
export default site;
Creating pages in Markdown
To create a page using Markdown, just add a file with .md
extension to your site. You can also add extra variables by including a front matter, a block delimited by two triple-dashed lines with YAML code:
---
title: Welcome to my page
layout: layouts/main.njk
---
# Welcome
**This is my first post** using Lume.
I hope you like it!
The Markdown code is stored in the content
variable:
<html>
<head>
<title>{{ title }}</title>
</head>
<body>
{{ content | safe }}
</body>
</html>
md filter
The Markdown plugin also registers the md
filter that renders any string value as Markdown and outputs an HTML fragment. The filter also accepts an argument to render the Markdown in inline mode.
<!-- Render to HTML code -->
<div>{{ text | md }}</div>
<!-- Single line rendering, without the paragraph wrap: -->
<p>{{ text | md(true) }}</p>