Include jekyll / liquid template data in a YAML variable?

后端 未结 2 1754
南方客
南方客 2020-12-01 02:14

I am using the YAML heading of a markdown file to add an excerpt variable to blog posts that I can use elsewhere. In one of these excerpts I refer to an earlier

相关标签:
2条回答
  • 2020-12-01 02:39

    I don't believe it's possible to nest liquid variables inside YAML. At least, I haven't figure out how to do it.

    One approach that will work is to use a Liquid's replace filter. Specifically, define a string that you want to use for the variable replacement (e.g. !SITE_URL!). Then, use the replace filter to switch that to your desired Jekyll variable (e.g. site.url) during the output. Here's a cut down .md file that behaves as expected on my jekyll 0.11 install:

    ---
    layout: post
    
    excerpt: In the [earlier post in this series](!SITE_URL!/2013/01/12/)
    
    ---
    
    {{ page.excerpt | replace: '!SITE_URL!', site.url }}
    

    Testing that on my machine, the URL is inserted properly and then translated from markdown into an HTML link as expected. If you have more than one item to replace, you can string multiple replace calls together.

    ---
    layout: post
    
    my_name: Alan W. Smith
    multi_replace_test: 'Name: !PAGE_MY_NAME! - Site: [!SITE_URL!](!SITE_URL!)'
    
    ---
    
    {{ page.multi_replace_test | replace: '!SITE_URL!', site.url | replace: '!PAGE_MY_NAME!', page.my_name }}
    

    An important note is that you must explicitly set the site.url value. You don't get that for free with Jekyll. You can either set it in your _config.yml file with:

    url: http://alanwsmith.com
    

    Or, define it when you call jekyll:

    jekyll --url http://alanwsmith.com
    
    0 讨论(0)
  • 2020-12-01 02:48

    Today I ran into a similar problem. As a solution I created the following simple Jekyll filter-plugin which allows to expand nested liquid-templates in (e.g. liquid-variables in the YAML front matter):

    module Jekyll
      module LiquifyFilter
        def liquify(input)
          Liquid::Template.parse(input).render(@context)
        end
      end
    end
    
    Liquid::Template.register_filter(Jekyll::LiquifyFilter)
    

    Filters can be added to a Jekyll site by placing them in the '_plugins' sub-directory of the site-root dir. The above code can be simply pasted into a yoursite/_plugins/liquify_filter.rb file.

    After that a template like...

    ---
    layout: default
    first_name: Harry
    last_name: Potter
    greetings: Greetings {{ page.first_name }} {{ page.last_name }}!
    ---
    {{ page.greetings | liquify }}
    

    ... should render some output like "Greetings Harry Potter!". The expansion works also for deeper nested structures - as long as the liquify filter is also specified on the inner liquid output-blocks. Something like {{ site.url }} works of course, too.

    Update - looks like this is now available as a Ruby gem: https://github.com/gemfarmer/jekyll-liquify.

    0 讨论(0)
提交回复
热议问题