--- title: "Markdown Render Hooks" linkTitle: "Render Hooks" description: "Render Hooks allow custom templates to override markdown rendering functionality." date: 2017-03-11 categories: [templates] keywords: [markdown] toc: true menu: docs: title: "Markdown Render Hooks" parent: "templates" weight: 20 --- {{< new-in "0.62.0" >}} Note that this is only supported with the [Goldmark](/getting-started/configuration-markup#goldmark) renderer. You can override certain parts of the default Markdown rendering to HTML by creating templates with base names `render-{kind}` in `layouts/_default/_markup`. You can also create type/section specific hooks in `layouts/[type/section]/_markup`, e.g.: `layouts/blog/_markup`.{{< new-in "0.71.0" >}} The hook kinds currently supported are: * `image` * `link` * `heading` {{< new-in "0.71.0" >}} * `codeblock`{{< new-in "0.93.0" >}} You can define [Output-Format-](/templates/output-formats) and [language-](/content-management/multilingual/)specific templates if needed. Your `layouts` folder may look like this: ```goat { class="black f7" } layouts └── _default └── _markup ├── render-image.html ├── render-image.rss.xml └── render-link.html └── render-codeblock.html └── render-codeblock-bash.html ``` Some use cases for the above: * Resolve link references using `.GetPage`. This would make links portable as you could translate `./my-post.md` (and similar constructs that would work on GitHub) into `/blog/2019/01/01/my-post/` etc. * Add `target=_blank` to external links. * Resolve and [process](/content-management/image-processing/) images. * Add [header links](https://remysharp.com/2014/08/08/automatic-permalinks-for-blog-posts). ## Render Hooks for Headings, Links and Images The `render-link` and `render-image` templates will receive this context: Page : The [Page](/variables/page/) being rendered. Destination : The URL. Title : The title attribute. Text : The rendered (HTML) link text. PlainText : The plain variant of the above. The `render-heading` template will receive this context: Page : The [Page](/variables/page/) being rendered. Level : The header level (1--6) Anchor : An auto-generated html id unique to the header within the page Text : The rendered (HTML) text. PlainText : The plain variant of the above. Attributes (map) {{< new-in "0.82.0" >}} : A map of attributes (e.g. `id`, `class`) ### Link with title Markdown example: ```md [Text](https://www.gohugo.io "Title") ``` Here is a code example for how the render-link.html template could look: {{< code file="layouts/_default/_markup/render-link.html" >}} {{ .Text | safeHTML }} {{< /code >}} ### Image Markdown example: ```md ![Text](https://d33wubrfki0l68.cloudfront.net/c38c7334cc3f23585738e40334284fddcaf03d5e/2e17c/images/hugo-logo-wide.svg "Title") ``` Here is a code example for how the render-image.html template could look: {{< code file="layouts/_default/_markup/render-image.html" >}}
{{< /code >}} ### Heading link example Given this template file {{< code file="layouts/_default/_markup/render-heading.html" >}}