hugo

Fork of github.com/gohugoio/hugo with reverse pagination support

git clone git://git.shimmy1996.com/hugo.git

render-hooks.md (5381B)

    1 ---
    2 title: "Markdown Render Hooks"
    3 linkTitle: "Render Hooks"
    4 description: "Render Hooks allow custom templates to override markdown rendering functionality."
    5 date: 2017-03-11
    6 categories: [templates]
    7 keywords: [markdown]
    8 toc: true
    9 menu:
   10   docs:
   11     title: "Markdown Render Hooks"
   12     parent: "templates"
   13     weight: 20
   14 ---
   15 
   16 {{< new-in "0.62.0" >}} Note that this is only supported with the [Goldmark](/getting-started/configuration-markup#goldmark) renderer.
   17 
   18 
   19 You can override certain parts of the default Markdown rendering to HTML by creating templates with base names `render-{kind}` in `layouts/_default/_markup`.
   20 
   21 You can also create type/section specific hooks in `layouts/[type/section]/_markup`, e.g.: `layouts/blog/_markup`.{{< new-in "0.71.0" >}}
   22 
   23 The hook kinds currently supported are:
   24 
   25 * `image`
   26 * `link`
   27 * `heading` {{< new-in "0.71.0" >}}
   28 * `codeblock`{{< new-in "0.93.0" >}}
   29 
   30 You can define [Output-Format-](/templates/output-formats) and [language-](/content-management/multilingual/)specific templates if needed. Your `layouts` folder may look like this:
   31 
   32 ```goat { class="black f7" }
   33 layouts
   34 └── _default
   35     └── _markup
   36         ├── render-image.html
   37         ├── render-image.rss.xml
   38         └── render-link.html
   39         └── render-codeblock.html
   40         └── render-codeblock-bash.html
   41 ```
   42 
   43 Some use cases for the above:
   44 
   45 * 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.
   46 * Add `target=_blank` to external links.
   47 * Resolve and [process](/content-management/image-processing/) images.
   48 * Add [header links](https://remysharp.com/2014/08/08/automatic-permalinks-for-blog-posts).
   49 
   50 ## Render Hooks for Headings, Links and Images
   51 
   52 The `render-link` and `render-image` templates will receive this context:
   53 
   54 Page
   55 : The [Page](/variables/page/) being rendered.
   56 
   57 Destination
   58 : The URL.
   59 
   60 Title
   61 : The title attribute.
   62 
   63 Text
   64 : The rendered (HTML) link text.
   65 
   66 PlainText
   67 : The plain variant of the above.
   68 
   69 The `render-heading` template will receive this context:
   70 
   71 Page
   72 : The [Page](/variables/page/) being rendered.
   73 
   74 Level
   75 : The header level (1--6)
   76 
   77 Anchor
   78 : An auto-generated html id unique to the header within the page
   79 
   80 Text
   81 : The rendered (HTML) text.
   82 
   83 PlainText
   84 : The plain variant of the above.
   85 
   86 Attributes (map) {{< new-in "0.82.0" >}}
   87 : A map of attributes (e.g. `id`, `class`)
   88 
   89 ### Link with title Markdown example:
   90 
   91 ```md
   92 [Text](https://www.gohugo.io "Title")
   93 ```
   94 
   95 Here is a code example for how the render-link.html template could look:
   96 
   97 {{< code file="layouts/_default/_markup/render-link.html" >}}
   98 <a href="{{ .Destination | safeURL }}"{{ with .Title}} title="{{ . }}"{{ end }}{{ if strings.HasPrefix .Destination "http" }} target="_blank" rel="noopener"{{ end }}>{{ .Text | safeHTML }}</a>
   99 {{< /code >}}
  100 
  101 ### Image Markdown example:
  102 
  103 ```md
  104 ![Text](https://d33wubrfki0l68.cloudfront.net/c38c7334cc3f23585738e40334284fddcaf03d5e/2e17c/images/hugo-logo-wide.svg "Title")
  105 ```
  106 
  107 Here is a code example for how the render-image.html template could look:
  108 
  109 {{< code file="layouts/_default/_markup/render-image.html" >}}
  110 <p class="md__image">
  111   <img src="{{ .Destination | safeURL }}" alt="{{ .Text }}" {{ with .Title}} title="{{ . }}"{{ end }} />
  112 </p>
  113 {{< /code >}}
  114 
  115 ### Heading link example
  116 
  117 Given this template file
  118 
  119 {{< code file="layouts/_default/_markup/render-heading.html" >}}
  120 <h{{ .Level }} id="{{ .Anchor | safeURL }}">{{ .Text | safeHTML }} <a href="#{{ .Anchor | safeURL }}">¶</a></h{{ .Level }}>
  121 {{< /code >}}
  122 
  123 And this markdown
  124 
  125 ```md
  126 ### Section A
  127 ```
  128 
  129 The rendered html will be
  130 
  131 ```html
  132 <h3 id="section-a">Section A <a href="#section-a">¶</a></h3>
  133 ```
  134 
  135 ## Render Hooks for Code Blocks
  136 
  137 {{< new-in "0.93.0" >}}
  138 
  139 You can add a hook template for either all code blocks or for a specific type/language (`bash` in the example below):
  140 
  141 ```goat { class="black f7" }
  142 layouts
  143 └── _default
  144     └── _markup
  145         └── render-codeblock.html
  146         └── render-codeblock-bash.html
  147 ```
  148 
  149 The default behaviour for these code blocks is to do [Code Highlighting](/content-management/syntax-highlighting/#highlighting-in-code-fences), but since you can pass attributes to these code blocks, they can be used for almost anything. One example would be the built-in [GoAT Diagrams](/content-management/diagrams/#goat-diagrams-ascii) or this [Mermaid Diagram Code Block Hook](/content-management/diagrams/#mermaid-diagrams) example.
  150 
  151 The context (the ".") you receive in a code block template contains:
  152 
  153 Type (string)
  154 : The type of code block. This will be the programming language, e.g. `bash`, when doing code highlighting.
  155 
  156 Attributes (map)
  157 : Attributes passed in from Markdown (e.g. `{ attrName1=attrValue1 attrName2="attr Value 2" }`).
  158 
  159 Options (map)
  160 : Chroma highlighting processing options. This will only be filled if `Type` is a known [Chroma Lexer](/content-management/syntax-highlighting/#list-of-chroma-highlighting-languages).
  161 
  162 Inner (string)
  163 : The text between the code fences.
  164 
  165 Ordinal (integer)
  166 : Zero-based ordinal for all code blocks in the current document.
  167 
  168 Page
  169 : The owning `Page`.
  170 
  171 Position
  172 : Useful in error logging as it prints the filename and position (linenumber, column), e.g. `{{ errorf "error in code block: %s" .Position }}`.