Jekyll/Liquid Variable Filters

Published: | Updated: | by Julian Knight Reading time ~9 min.
đź“– Kb | đź“Ž Development | đź”– Jekyll, Static Site Generators

A comprehensive list of filters available to modify/format Jekyll variables.

GitHub pages use Jekyll which in turn uses Liquid.

Liquid provides the variable filters that can be used to amend/format the variable for output.

This is a more comprehensive list than you will find in most places, it is combined from multiple lists including the source documentation. For more details on these filters, see the official filter documentation.

  • abs - absolute value

  • absolute_url - Prepend the url and baseurl value to the input. e.g. {{ "/assets/style.css" | absolute_url }} #=> http://example.com/my-baseurl/assets/style.css

  • append - append a string e.g. {{ 'foo' | append:'bar' }} #=> 'foobar'

  • array_to_sentence_string - Convert an array into a sentence. Useful for listing tags. Optional argument for connector. e.g. {{ page.tags | array_to_sentence_string: 'or' }} #=> foo, bar, or baz

  • capitalize - capitalize words in the input sentence

  • ceil - rounds a number up to the nearest integer, e.g. {{ 4.6 | ceil }} #=> 5

  • compact - Remove nils within an array provide optional property with which to check for nil.

  • concat - Concatenates (combines) an array with another array

  • cgi_escape - Replaces any special characters with appropriate %XX replacements. CGI escape normally replaces a space with a plus + sign.

  • date - reformat a date (syntax reference)

    Reformat a date using Ruby’s core Time#strftime( string ) -> string

    %a - The abbreviated weekday name (``Sun'')
    %A - The  full  weekday  name (``Sunday'')
    %b - The abbreviated month name (``Jan'')
    %B - The  full  month  name (``January'')
    %c - The preferred local date and time representation
    %d - Day of the month (01..31)
    %H - Hour of the day, 24-hour clock (00..23)
    %I - Hour of the day, 12-hour clock (01..12)
    %j - Day of the year (001..366)
    %m - Month of the year (01..12)
    %M - Minute of the hour (00..59)
    %p - Meridian indicator (``AM''  or  ``PM'')
    %s - Number of seconds since 1970-01-01 00:00:00 UTC.
    %S - Second of the minute (00..60)
    %U - Week  number  of the current year,
            starting with the first Sunday as the first
            day of the first week (00..53)
    %W - Week  number  of the current year,
            starting with the first Monday as the first
            day of the first week (00..53)
    %w - Day of the week (Sunday is 0, 0..6)
    %x - Preferred representation for the date alone, no time
    %X - Preferred representation for the time alone, no date
    %y - Year without a century (00..99)
    %Y - Year with century
    %Z - Time zone name
    %% - Literal ``%'' character
    

    See also: http://www.ruby-doc.org/core/Time.html#method-i-strftime

  • date_to_long_string - Format a date to long format. e.g. 07 November 2008

  • date_to_rfc822 - Convert a Date into the RFC-822 format used for RSS feeds.

  • date_to_string - Convert a date to short format. e.g. 07 Nov 2008

  • date_to_xmlschema - Convert a Date into XML Schema (ISO 8601) format.

  • default - returns the given variable unless it is null or the empty string, when it will return the given value, e.g. {{ undefined_variable | default: "Default value" }} #=> "Default value"

  • default_errors -

  • default_pagination -

  • divided_by - integer division e.g. {{ 10 | divided_by:3 }} #=> 3

  • downcase - convert an input string to lowercase

  • escape - html escape a string

  • escape_once - returns an escaped version of html without affecting existing escaped entities

  • first - get the first element of the passed-in array

  • floor - rounds a number down to the nearest integer, e.g. {{ 4.6 | floor }} #=> 4

  • gist (provided by jekyll-gist plugin) - display a gist. e.g. {% gist c08ee0f2726fd0e3909d %}

  • group_by - group elements from array by given property: {{ site.posts | group_by:"category" }}

  • group_by_exp - Group an array’s items using a Liquid expression. e.g. {{ site.members | group_by_exp:"item","item.graduation_year | truncate: 3, \"\"" }} #=> [{"name"=>"201...", "items"=>[...]},{"name"=>"200...", "items"=>[...]}]

  • highlight - Wraps words inside search results with an HTML <strong> tag with the class highlight if it matches the submitted search.terms. Has to be used in a search form. Does this work in Jekyll? Not to be confused with the highlight tag.

  • highlight_active_tag - Wraps a tag link in a <span> with the class active if that tag is being used to filter a collection.

  • img_tag - generate an img html tag

  • inspect - Convert an object into its String representation for debugging. Returns a JSON stringified version of a variable so use as <pre>{{ page | inspect }}</pre> - possibly references Ruby’s inspect function?

  • join - join elements of the array with certain character between them

  • json - Converts a string into JSON format.

    You do not have to wrap the Liquid output in quotations - the json filter will add them in. The json filter will also escape quotes as needed inside the output. The json filter can also used to make Liquid objects readable by JavaScript.

  • jsonify - convert data to JSON: {{ site.data.dinosaurs | jsonify }}

  • last - get the last element of the passed in array

  • lstrip - strips all whitespace from the beginning of a string

  • map - map/collect an array on a given property

  • markdownify - convert markdown to HTML

  • minus - subtraction e.g. {{ 4 | minus:2 }} #=> 2

  • modulo - remainder, e.g. {{ 3 | modulo:2 }} #=> 1

  • newline_to_br - replace each newline (\n) with html break

  • normalize_whitespace - Replace any occurrence of whitespace with a single space.

  • number_of_words - Count the number of words in some text.

  • placeholder_svg_tag

  • plus - addition e.g. {{ '1' | plus:'1' }} #=> 2, {{ 1 | plus:1 }} #=> 2

  • pop - Remove an entry from the end of an array. Non-destructive, makes a copy of the array and changes that.

  • prepend - prepend a string e.g. {{ 'bar' | prepend:'foo' }} #=> 'foobar'

  • push - Add entry to the end of an array. Non-destructive, makes a copy of the array and changes that.

  • relative_url - Prepend the baseurl value to the input. Useful if your site is hosted at a subpath rather than the root of the domain. e.g. {{ "/assets/style.css" | relative_url }} #=> /my-baseurl/assets/style.css

  • remove - remove each occurrence e.g. {{ 'foobarfoobar' | remove:'foo' }} #=> 'barbar'

  • remove_first - remove the first occurrence e.g. {{ 'barbar' | remove_first:'bar' }} #=> 'bar'

  • replace - replace each occurrence e.g. {{ 'foofoo' | replace:'foo','bar' }} #=> 'barbar'

  • replace_first - replace the first occurrence e.g. {{ 'barbar' | replace_first:'bar','foo' }} #=> 'foobar'

  • reverse - reverses the passed in array

  • round - rounds input to the nearest integer or specified number of decimals e.g. {{ 4.5612 | round: 2 }} #=> 4.56

  • rstrip - strips all whitespace from the end of a string

  • sample - Pick a random value from an array. Optionally provide a number to pick multiple values.

  • sassify - Convert a Sass-formatted string into CSS.

  • script_tag - generate a script html tag

  • scssify - Convert a Scss-formatted string into CSS.

  • shift - Add entry to the start of an array. Non-destructive, makes a copy of the array and changes that.

  • size - return the size of an array or string

  • slice - slice a string. Takes an offset and length, e.g. {{ "hello" | slice: -3, 3 }} #=> llo

  • slugify - Convert a string into a lowercase URL “slug”. Optionally takes a style parameter: none, raw, default, pretty, ascii, latin. Definitions for permalink styles

  • sort - sort elements of the array

  • sort_natural - Sort elements of an array ignoring case if strings provide optional property with which to sort an array of hashes or drops.

  • smartify - Convert “quotes” into “smart quotes.”

  • split - split a string on a matching pattern e.g. {{ "a~b" | split:"~" }} #=> ['a','b']

  • strip - strips all whitespace from both ends of the string

  • strip_html - strip html from string

  • strip_newlines - strip all newlines (\n) from string

  • stylesheet_tag - generate a stylesheet html tag

  • times - multiplication e.g {{ 5 | times:4 }} #=> 20

  • to_integer - Convert a string or boolean to integer.

  • truncate - truncate a string down to x characters. It also accepts a second parameter that will append to the string e.g. {{ 'foobarfoobar' | truncate: 5, '.' }} #=> 'foob.'

  • truncatewords - truncate a string down to x words

  • uniq - remove duplicate elements from an array, optionally using a given property to test for uniqueness

  • unshift - Remove an entry from the start of an array. Non-destructive, makes a copy of the array and changes that.

  • upcase - convert an input string to uppercase

  • uri_escape - Percent encodes any special characters in a URI. URI escape normally replaces a space with %20. Reserved characters will not be escaped.

  • url_decode - url decode a string

  • url_encode - url encode a string

  • where - select elements from array with given property value: {{ site.posts | where:"category","foo" }}

  • where_exp - Select all the objects in an array where the expression is true. Jekyll v3.2.0 & later. e.g. {{ site.members | where_exp:"item","item.graduation_year == 2014" }} {{ site.members | where_exp:"item","item.graduation_year < 2014" }} {{ site.members | where_exp:"item","item.projects contains 'foo'" }}

  • xml_escape - Escape some text for use in XML.

Liquid filters that don’t work in Jekyll 🔗︎

  • These math filters don’t work:

    • at_least - Limits a number to a minimum value.
    • at_most - Limits a number to a maximum value.
  • Not all of the string filters work:

    • The hashing filters don’t work
    • camelcase
    • pluralize
    • time_tag
  • Not all of the utility filters work:

    • weight_with_unit - Formats a number with the default weight unit. The unit can be overridden by passing it into the filter.
    • format_address
  • The money filters don’t appear to work.

  • The colour filters don’t seem to work:

    • color_brightness - Calculates the perceived brightness of the given color. Uses W3C recommendations for calculating perceived brightness, for the purpose of ensuring adequate contrast.
    • color_darken - Darkens the input color. Takes a value between 0 and 100 percent.
    • color_desaturate - Desaturates the input color. Takes a value between 0 and 100 percent.
    • color_extract - Extracts a component from the color. Valid components are alpha, red, green, blue, hue, saturation and lightness.
    • color_lighten - Lightens the input color. Takes a value between 0 and 100 percent.
    • color_mix - Blends together two colors. Blend factor should be a value value between 0 and 100 percent.
    • color_modify - Modifies the given component of a color. {{ '#7ab55c' | color_modify: 'red', 255 }} #=> #ffb55c
    • color_saturate - Saturates the input color. Takes a value between 0 and 100 percent.
    • color_to_hex - Converts a CSS color string to hex6 format.
    • color_to_hsl - Converts a CSS color string to CSS hsl() format.
    • color_to_rgb - Converts a CSS color string to CSS rgb() format.