How to Use Content in Meta Tags in Jekyll

Stack Overflow: In Jekyll How do I grab a post’s first image? A lot of different answers to this one, but I went with an answer that was not the “accepted” answer: installing a Liquid regex gem/plugin. I only had one improvement. Here are the steps and final code I landed with:

Per the instructions, install the gem and add it to Jekyll’s plugin list. I use bundler to manage gems for this site, so I just added it to my Gemfile.rb.

gem "match_regex"
plugins:
  - match_regex

And then I refactored the example liquid from SO a little bit, since the capture wasn’t necessary, as the variable was being assigned already:

{% assign hero_image = page.content | match_regex: '<img .*?src="([^"]+)"' %}
{% if hero_image == nil %}
  {% assign hero_image = "/assets/page/DSC_4899-copy.jpg" %}
{% endif %}
{% assign hero_image = hero_image | prepend: site.url %}

Then I needed some extra logic to conditionally grab some other metadata:

{% capture title %}
  {% if page.title %}
    {{ page.title }}
  {% else %}
    {{ site.title }}
  {% endif %}
{% endcapture %}

{% capture description %}
  {% if page.excerpt %}
    {{ page.excerpt | strip_html | escape }}
  {% else %}
    {{ site.tagline }}
  {% endif %}
{% endcapture %}

Then I used snaplink.dev to generate an image for the og:image tag:

<title>{{ title }}</title>
<meta name="description" content="{{ description | strip }}">
<meta property="og:title" content="{{ title | strip }}" />
<meta property="og:description" content="{{ description | strip }}" />
<meta property="og:image" content="https://img.snaplink.dev/59d2d71912/?title={{ title | strip | url_encode }}&excerpt={{ description | strip | url_encode }}&image={{ hero_image | url_encode }}&w=1200&h=630" />
Previous: How to Install Gmail as a PWA

Archives | Blogroll | RSS