Tilgængelige Liquid-filtre
Liquid-filtre bruges til at ændre outputtet af strenge, tal, variabler og objekter. De er adskilt fra den værdi, som de anvendes på, af en |.
{{ 'hal 9000' | upcase }} <!-- Output: HAL 9000 -->
Nogle filtre accepterer parametre. Filtre kan også kombineres og anvendes i rækkefølge fra venstre mod højre.
{{ 2 | times: 2 | minus: 1 }} <!-- Output: 3 -->
{{ "Hello, " | append: user.firstname }} <!-- Output: Hello, Dave -->
I nedenstående sektion beskrives forskellige filtre.
Matrixfiltre
Matrixfiltre bruges til at arbejde med matricer.
batch
Opdeler en matrix i flere matricer af en given størrelse.
Kode
{% assign batches = entityview.records | batch: 2 %}
{% for batch in batches %}
<ul>
{% for item in batch %}
<li>{{ item.fullname }}</li>
{% endfor %}
</ul>
{% endfor %}
Resultat
<ul>
<li>John Smith</li>
<li>Dave Thomas</li>
</ul>
<ul>
<li>Jake Johnson</li>
<li>Jack Robinson</li>
</ul>
concat
Sammenkæder to matricer i et enkelt nyt system.
Med et enkelt element som parameter returnerer concat en nyt matrix, der består af den oprindelige matrix med det angivne element som det sidste element.
Kode
Group #1: {{ group1 | join: ', ' }}
Group #2: {{ group2 | join: ', ' }}
Group #1 + Group #2: {{ group1 | concat: group2 | join: ', ' }}
Resultat
Group #1: John, Pete, Hannah
Group #2: Joan, Bill
Group #1 + Group #2: John, Pete, Hannah, Joan, Bill
except
Markerer alle objekter i en matrix, hvor en given attribut ikke har en angivet værdi. (Dette er det omvendte af where).
Kode
{% assign redmond = entityview.records | except: 'address1_city', 'Redmond' %}
{% for item in redmond %}
{{ item.fullname }}
{% endfor %}
Output
Jack Robinson
Første
Returnerer det første element i en matrix.
first kan også bruges sammen med en speciel punktnotation i tilfælde, hvor det skal bruges i et mærke.
Kode
{% assign words = This is a run of text | split: %}
{{ words | first }}
{% if words.first == This %}
The first word is This.
{% endif %}
Resultat
This
The first word is This.
group_by
Grupperer elementerne i en matrix efter en bestemt attribut.
Kode
{% assign groups = entityview.records | group_by: 'address1_city' %}
{% for group in groups %}
{{ group.key }}:
{% for item in group.items %}
{{ item.fullname }}
{% endfor %}
{% endfor %}
Resultat
Redmond:
John Smith
Dave Thomas
Jake Johnson
New York:
Jack Robinson
join
Forbinder elementerne i en matrix med det tegn, der er overført som parameter. Resultatet er en enkelt streng.
Kode
{% assign words = This is a run of text | split: %}
{{ words | join: , }}
Resultat
This, is, a, run, of, text
Sidste
Returnerer det sidste element i en matrix.
last kan også bruges sammen med en speciel punktnotation i tilfælde, hvor det skal bruges i et mærke.
Kode
{% assign words = This is a run of text | split: -%}
{{ words | last }}
{% if words.last == text -%}
The last word is text.
{% endif -%}
Output
text
The last word is text.
order_by
Returnerer elementerne i en matrix, der er arrangeret efter en given attribut for elementerne i matricen.
Du kan eventuelt angive desc som en anden parameter for at sortere elementerne i faldende rækkefølge i stedet for stigende.
Kode
{{ entityview.records | order_by: 'fullname' | join: ', ' }}
{{ entityview.records | order_by: 'fullname', 'desc' | join: ', ' }}
Output
Dave Thomas, Jack Robinson, Jake Johnson, John Smith
John Smith, Jake Johnson, Jack Robinson, Dave Thomas
random
Returnerer et enkelt tilfældigt udvalgt element fra matricen.
Kode
{{ group1 | join: ', ' }}
{{ group1 | random }}
Output
John, Pete, Hannah
Pete
select
Vælger værdien af en bestemt attribut for hvert element i en matrix og returnerer værdierne som en matrix.
Kode
{{ entityview.records | select: 'address1_city' | join: ', ' }}
Resultat
Redmond, New York
shuffle
Anvendes på en matrix, returnerer en nyt matrix med de samme elementer i randomiseret rækkefølge.
Kode
{{ group1 | join: ', ' }}
{{ group1 | shuffle | join: ', ' }}
Resultat
John, Pete, Hannah
Hannah, John, Pete
size
Returnerer antallet af elementer i en matrix.
size kan også bruges sammen med en speciel punktnotation i tilfælde, hvor det skal bruges i et mærke.
Kode
{% assign words = This is a run of text | split: -%}
{{ words | size }}
{% if words.size == 6 -%}
The text contains 6 words.
{% endif -%}
Resultat
6
The text contains 6 words.
skip
Springer over et givet antal elementer i en matrix og returnerer resten.
Kode
{% assign words = This is a run of text | split: %}
{{ words | skip: 3 | join: ', ' }}
Resultat
run, of, text
take
Tager et givet antal elementer i matricen og returnerer de elementer, der er tages.
Kode
{% assign words = This is a run of text | split: %}
{{ words | take: 3 | join: ', ' }}
Output
This, is, a
then_by
Tilføjer yderligere efterfølgende rangering i en matrix, der allerede er sorteret efter order_by.
Du kan eventuelt angive desc som en anden parameter for at sortere elementerne i faldende rækkefølge i stedet for stigende.
Kode
{{ entityview.records | order_by: 'address1_city' | then_by: 'fullname' | join: ', ' }}
{{ entityview.records | order_by: 'address1_city' | then_by: 'fullname', 'desc' | join: ', ' }}
Resultat
Dave Thomas, Jack Robinson, Jake Johnson, John Smith
John Smith, Jake Johnson, Jack Robinson, Dave Thomas
hvor
Markerer alle objekter i en matrix, hvor en given attribut har en angivet værdi.
Kode
{% assign redmond = entityview.records | where: 'address1_city', 'Redmond' %}
{% for item in redmond %}
{{ item.fullname }}
{% endfor %}
Resultat
John Smith
Dave Thomas
Jake Johnson
Datofiltre
Datofiltre kan bruges til datoaritmetik eller til at konvertere DateTime-værdier til forskellige formater.
dato
Formaterer en DateTime-værdi ved hjælp af en .NET-formatstreng.
Standarddato- og klokkeslætsformatstrenge
Brugerdefinerede dato- og klokkeslætsformatstrenge
Kode
{{ now | date: 'g' }}
{{ now | date: 'MMMM dd, yyyy' }}
Output
5/7/2018 7:20 AM
May 07, 2018
date_add_days
Føjer det angivne antal hele dage og dele af dage til DateTime-værdien. Parameteren kan være positiv eller negativ.
Kode
{{ now }}
{{ now | date_add_days: 1 }}
{{ now | date_add_days: -2.5 }}
Output
5/7/2018 7:20:46 AM
5/8/2018 7:20:46 AM
5/4/2018 7:20:46 PM
date_add_hours
Føjer det angivne antal af hele timer og dele af timer til DateTime-værdien. Parameteren kan være positiv eller negativ.
Kode
{{ now }}
{{ now | date_add_hours: 1 }}
{{ now | date_add_hours: -2.5 }}
Output
5/7/2018 7:20:46 AM
5/7/2018 8:20:46 AM
5/7/2018 4:50:46 AM
date_add_minutes
Føjer det angivne antal af hele minutter og dele af minutter til DateTime-værdien. Parameteren kan være positiv eller negativ.
Kode
{{ now }}
{{ now | date_add_minutes: 10 }}
{{ now | date_add_minutes: -2.5 }}
Output
5/7/2018 7:20:46 AM
5/7/2018 7:30:46 AM
5/7/2018 7:18:16 AM
date_add_months
Føjer det angivne antal af hele måneder og dele af måneder til DateTime-værdien. Parameteren kan være positiv eller negativ.
Kode
{{ now }}
{{ now | date_add_months: 1 }}
{{ now | date_add_months: -2 }}
Output
5/7/2018 7:20:46 AM
6/7/2018 7:20:46 AM
3/7/2018 7:20:46 AM
date_add_seconds
Føjer det angivne antal af hele sekunder og dele af sekunder til DateTime-værdien. Parameteren kan være positiv eller negativ.
Kode
{{ now }}
{{ now | date_add_seconds: 10 }}
{{ now | date_add_seconds: -1.25 }}
Output
5/7/2018 7:20:46 AM
5/7/2018 7:20:56 AM
5/7/2018 7:20:45 AM
date_add_years
Føjer det angivne antal af hele år og dele af år til DateTime-værdien. Parameteren kan være positiv eller negativ.
Kode
{{ now }}
{{ now | date_add_years: 1 }}
{{ now | date_add_years: -2 }}
Output
5/7/2018 7:20:46 AM
5/7/2019 7:20:46 AM
5/7/2016 7:20:46 AM
date_to_iso8601
Formaterer en DateTime-værdi i henhold til ISO 8601-standarden. Nyttig, når du opretter Atom-feeds eller HTML5 <time>-elementet.
Kode
{{ now | date_to_iso8601 }}
Output
2018-05-07T07:20:46Z
date_to_rfc822
Formaterer en DateTime-værdi i henhold til RFC 822-standarden. Nyttigt, når du opretter RSS-feeds.
Kode
{{ now | date_to_rfc822 }}
Output
Mon, 07 May 2018 07:20:46 Z
Escape-filtre
Escape-sekvenser kan bruges til at inkludere specialtegn i strenge uden at være i konflikt med den almindelige brug af disse tegn efter programmeringssprog eller -format.
Følgende escape-filtre erstatter strengtegn med escape-sekvenser eller fjerner ugyldige strengtegn baseret på destinationstypen.
escape
HTML-escaper en streng.
Kode
{{ '<p>test</p>' | escape }}
Output
<p>test</p>
html_safe_escape
Konverterer en given HTML-streng til et sikkert HTML-fragment.
Kode
{{ '<img src="images/myimage.jpg" onerror="alert(1);">' | html_safe_escape }}
Output
<img src="images/myimage.jpg">
url_escape
URI-escaper en streng, så den kan medtages i en URL-adresse.
Kode
{{ 'This & that//' | url_escape }}
Output
This+%26+that%2F%2F
xml_escape
XML-escaper en streng, så den kan medtages i XML-output.
Kode
{{ '<p>test</p>' | xml_escape }}
Output
<p>test</p>
Listefiltre
Listefiltre bruges til at arbejde med visse entitylist-attributværdier og til at hjælpe med at oprette listevisninger.
current_sort
Givet et sorteringsudtryk returneres den aktuelle sorteringsrækkefølge for en bestemt attribut.
Kode
{{ 'name ASC, createdon DESC' | current_sort: 'createdon' }}
Output
DESC
metafilters
Parser en entitylist-filter_definition JSON-værdi til gruppeobjekter for filterindstillinger.
metafiltre kan eventuelt forsynes med en forespørgsel på et aktuelt attributfilter og en aktuel entitylist, så de returnerede filterobjekter markeres som enten valgte eller fravalgte.
Kode
{% assign filters = entitylist | metafilters: params.mf, entityview %}
{% if filters.size > 0 %}
<ul id=entitylist-filters>
{% for filter in filters %}
<li class=entitylist-filter-option-group>
{% if filter.selection_mode == 'Single' %}
{% assign type = 'radio' %}
{% else %}
{% assign type = 'checkbox' %}
{% endif %}
<h4 class=entitylist-filter-option-group-label
data-filter-id={{ filter.id | h }}>
{{ filter.label | h }}
</h4>
<ul>
{% for option in filter.options %}
<li class=entitylist-filter-option>
{% if option.type == 'text' %}
<div class=input-group entitylist-filter-option-text>
<span class=input-group-addon>
<span class=fa fa-filter aria-hidden=true></span>
</span>
<input class=form-control
type=text
name={{ filter.id | h }}
value={{ option.text | h }} />
</div>
{% else %}
<div class={{ type | h }}>
<label>
<input
type={{ type | h }}
name={{ filter.id | h }}
value={{ option.id | h }}
{% if option.checked %}
checked=checked
data-checked=true{% endif %}
/>
{{ option.label | h }}
</label>
</div>
{% endif %}
</li>
{% endfor %}
</ul>
</li>
{% endfor %}
</ul>
<button class=btn btn-default data-serialized-query=mf data-target=#entitylist-filters>Apply Filters</button>
{% endif %}
reverse_sort
Givet en sorteringsretning returneres den modsatte sorteringsretning.
Kode
<!-- Sort direction is not case-sensitive -->
{{ 'ASC' | reverse_sort }}
{{ 'desc' | reverse_sort }}
Resultat
DESC
ASC
Matematiske filtre
Med matematiske filtre kan du udføre matematiske beregninger på tal.
Som med alle filtre kan matematikfiltre sammenkædes og anvendes i rækkefølge fra venstre mod højre.
Kode
{{ 10 | times: 2 | minus: 5 | divided_by: 3 }}
Resultat
5
ceil
Runder en værdi op til det nærmeste heltal.
Kode
{{ 4.6 | ceil }}
{{ 4.3 | ceil }}
Output
5
5
divided_by
Dividerer et tal med et andet tal.
Kode
{{ 10 | divided_by: 2 }}
{{ 10 | divided_by: 3 }}
{{ 10.0 | divided_by: 3 }}
Output
5
3
3.333333
floor
Runder en værdi ned til det nærmeste heltal.
Kode
{{ 4.6 | floor }}
{{ 4.3 | floor }}
Resultat
4
4
minus
Trækker et tal fra et andet tal.
Kode
<!-- entityview.page = 11 -->
{{ entityview.page | minus: 1 }}
{{ 10 | minus: 1.1 }}
{{ 10.1 | minus: 1 }}
Resultat
10
9
9.1
modulo
Dividerer et tal med et andet tal og returnerer resten.
Kode
{{ 12 | modulo: 5 }}
Resultat
2
plus
Lægger et tal til et andet tal.
Kode
<!-- entityview.page = 11 -->
{{ entityview.page | plus: 1 }}
{{ 10 | plus: 1.1 }}
{{ 10.1 | plus: 1 }}
Resultat
12
11
11.1
round
Afrunder en værdi til det nærmeste heltal eller det angivne antal decimaler.
Kode
{{ 4.6 | round }}
{{ 4.3 | round }}
{{ 4.5612 | round: 2 }}
Resultat
5
4
4.56
times
Ganger et tal med et andet tal.
Kode
{{ 10 | times: 2 }}
{{ 10 | times: 2.2 }}
{{ 10.1 | times: 2 }}
Resultat
20
20
20.2
Strengfiltre
Strengfiltre manipulerer Strenge.
append
Tilføjer en streng i slutningen af en anden streng.
Kode
{{ 'filename' | append: '.js' }}
Output
filename.js
capitalize
Giver alle ord i en streng stort begyndelsesbogstav.
Kode
{{ 'capitalize me' | capitalize }}
Output
Capitalize Me
downcase
Konverterer en streng til små bogstaver.
Kode
{{ 'MIxed Case TExt' | downcase }}
Output
mixed case text
newline_to_br
Indsætter et <br /> HTML-mærke for lineskift på hvert linjeskift i en streng.
Kode
{% capture text %}
A
B
C
{% endcapture %}
{{ text | newline_to_br }}
Resultat
A<br />
B<br />
C<br />
prepend
Tilføjer en streng i begyndelsen af en anden streng.
Kode
{{ 'Jane Johnson' | prepend: 'Dr. ' }}
Resultat
Dr. Jane Johnson
remove
Fjern alle forekomster af en understreng fra en streng.
Kode
{{ 'Hello, Dave. How are you, Dave?' | remove: 'Dave' }}
Output
Hello, . How are you, ?
remove_first
Fjerner den første forekomst af en understreng fra en streng.
Kode
{{ 'Hello, Dave. How are you, Dave?' | remove_first: 'Dave' }}
Resultat
Hello, . How are you, Dave?
replace
Erstatter alle forekomster af en streng med en understreng.
Kode
{{ 'Hello, Dave. How are you, Dave?' | replace: 'Dave', 'John' }}
Output
Hello, John. How are you, John?
replace_first
Erstatter den første forekomst af en streng med en understreng.
Kode
{{ 'Hello, Dave. How are you, Dave?' | replace_first: 'Dave', 'John' }}
Resultat
Hello, John. How are you, Dave?
split
Filteret split tager en understreng som parameter. Understrengen bruges som et afgrænsningstegn for at opdele en streng i en matrix.
Kode
{% assign words = This is a demo of the split filter | split: ' ' %}
First word: {{ words.first }}
First word: {{ words[0] }}
Second word: {{ words[1] }}
Last word: {{ words.last }}
All words: {{ words | join: ', ' }}
Output
First word: This
First word: This
Second word: is
Last word: filter
All words: This, is, a, demo, of, the, split, filter
strip_html
Fjerner alle HTML-mærker fra en streng.
Kode
<p>Hello</p>
Output
Hello
strip_newlines
Fjerner alle linjeskift fra en streng.
Kode
{% capture text %}
A
B
C
{% endcapture %}
{{ text | strip_newlines }}
Output
ABC
text_to_html
Formaterer en almindelig tekststreng som simpel HTML. Tekst er HTML-kodet, tekstblokke, der er adskilt af en tom linje, ombrydes i <p>-afsnitsmærker, enkelt linjeskift bliver udskiftet med <br>, og URL-adresser bliver konverteret til links.
Kode
{{ note.notetext | text_to_html }}
Output
<p>This is the first paragraph of notetext. It contains a URL: <a href="https://example.com/" rel="nofollow">https://example.com</a></p>
<p>This is a second paragraph.</p>
truncate
Afkorter en streng til et bestemt antal tegn. En ellipse (...) føjes til strengen og indgår i antallet af tegn.
Kode
{{ 'This is a long run of text.' | truncate: 10 }}
Output
This is...
truncate_words
Afkorter en streng til et bestemt antal ord. En ellipse (...) føjes til den forkortede streng.
Kode
{{ 'This is a long run of text.' | truncate_words: 3 }}
Output
This is a...
upcase
Konverterer en streng til store bogstaver.
Kode
{{ 'MIxed Case TExt' | upcase }}
Output
MIXED CASE TEXT
Typefiltre
Med typefiltre kan du konvertere værdier af én type til andre typer.
boolean
Forsøger at konvertere en strengværdi til en boolesk værdi. Hvis værdien allerede er boolesk, returneres den uændret. Hvis værdien ikke kan konverteres til en boolesk værdi, returneres null.
Dette filter accepterer også til, aktiveret eller ja som true, og fra, deaktiveret og nej som false.
Kode
{{ true | boolean }}
{{ 'false' | boolean }}
{{ 'enabled' | boolean }}
{{ settings['something/enabled'] | boolean | default: false }}
Resultat
true
false
true
false
decimal
Forsøger at konvertere en strengværdi til et decimaltal. Hvis værdien allerede er et decimaltal, returneres den uændret. Hvis værdien ikke kan konverteres til et decimaltal, returneres null.
Kode
{{ 10.1 | decimal }}
{{ '3.14' | decimal }}
{{ 'text' | decimal | default: 3.14 }}
Resultat
10.1
3.14
3.14
integer
Forsøger at konvertere en strengværdi til et heltal. Hvis værdien allerede er et heltal, returneres den uændret. Hvis værdien ikke kan konverteres til et heltal, returneres null.
Kode
{{ 10 | integer }}
{{ '10' | integer }}
{{ '10.1' | integer }}
{{ 'text' | integer | default: 2 }}
Output
10
10
2
string
Forsøger at konvertere en værdi til den tilsvarende strengrepræsentation. Hvis værdien allerede er en streng, returneres den uændret. Hvis værdien er null, returneres null.
URL-filtre
URL-filtre giver dig mulighed for at opbygge eller udtrækker dele af URL-adresser.
add_query
Føjer en forespørgselsstrengparameter til en URL-adresse. Hvis parameteren allerede findes i URL-adressen, opdateres værdien for parameteren.
Hvis dette filter anvendes på en fuldstændig, absolut URL-adresse, bliver resultatet en opdateret absolut URL-adresse. Hvis det anvendes på en sti, bliver en opdateret sti resultatet.
Kode
{{ 'https://example.com/path?page=1' | add_query: 'foo', 'bar' }}
{{ '/path?page=1' | add_query: 'page', 2 }}
Output
https://example.com/path?page=1&foo=bar
/path?page=2
base
Henter URL-rodadressen på en given URL-adresse.
Kode
{{ 'https://example.com/path?foo=bar&page=2' | base }}
Resultat
https://example.com
host
Henter værtsdelen af en URL-adresse.
Kode
{{ 'https://example.com/path?foo=bar&page=2' | host }}
Output
example.com
path
Henter stidelen af en URL-adresse.
Kode
{{ 'https://example.com/path?foo=bar&page=2' | path }}
{{ '/path?foo=bar&page=2' | path }}
Output
/path
/path
path_and_query
Henter sti- og forespørgselsdelen af en URL-adresse.
Kode
{{ 'https://example.com/path?foo=bar&page=2' | path_and_query }}
{{ '/path?foo=bar&page=2' | path_and_query }}
Output
/path?foo=bar&page=2
/path?foo=bar&page=2
port
Henter portnummeret af en URL-adresse.
Kode
{{ 'https://example.com/path?foo=bar&page=2' | port }}
{{ 'https://example.com/path?foo=bar&page=2' | port }}
{{ 'https://example.com:9000/path?foo=bar&page=2' | port }}
Output
80
443
9000
remove_query
Fjerner en forespørgselsstrengparameter fra en URL-adresse. Hvis parameteren ikke findes i URL-adressen, returneres URL-adressen uændret.
Hvis dette filter anvendes på en fuldstændig, absolut URL-adresse, bliver resultatet en opdateret absolut URL-adresse. Hvis det anvendes på en sti, bliver en opdateret sti resultatet.
Kode
{{ 'https://example.com/path?page=1' | remove_query: 'page' }}
{{ '/path?page=1' | remove_query: 'page' }}
Output
https://example.com/path
/path
scheme
Henter skemadelen af en URL-adresse.
Kode
{{ 'https://example.com/path?foo=bar&page=2' | scheme }}
{{ 'https://example.com/path?foo=bar&page=2' | scheme }}
Resultat
http
https
Flere filtre
Disse filtre indeholder praktiske generelle funktioner.
default
Returnerer en standardværdi for alle variabler uden tildelte værdi (dvs. null).
Kode
{{ snippets[Header] | default: 'My Website' }}
Output
<!-- If a snippet with the name Header returns null -->
My Website
file_size
Ved anvendelse på en talværdi, der repræsenterer mange bytes, returneres en formateret filstørrelse med en enhed i passende målestok.
Eventuelt kan en præcisionsparameter overføres for at kontrollere antallet af decimalpladser i resultatet. Standardpræcisionen er 1.
Kode
{{ 10000000 | file_size }}
{{ 2050 | file_size: 0 }}
{{ entity.notes.first.filesize | file_size: 2 }}
Output
9.5 MB
2 KB
207.14 KB
h
Angiver en HTML-repræsentation af en attribut. Viser f.eks. en HTML-repræsentation af FetchXML-forespørgslens XML-attribut.
Kode
{{ samplequery.xml | h }}
Output
<fetch mapping="logical" count="5000" page="1" returntotalrecordcount="true"> <entity name="contact"> <attribute name="fullname" /> </entity> </fetch>
has_role
Ved anvendelse på en user returneres true, hvis brugeren tilhører den angivne rolle. Returnerer false, hvis ikke.
Kode
{% assign is_admin = user | has_role: 'Administrators' %}
{% if is_admin %}
User is an administrator.
{% endif %}
liquid
Gengiver en streng som Liquid-kode. Denne kode har adgang til den aktuelle Liquid-kørselskontekst (variabler osv.).
Bemærk
Dette filter skal bruges med forsigtighed og bør normalt kun anvendes til værdier, der udelukkende styres af webstedets indholdsforfattere eller andre brugere, der har forstand på at skrive Liquid-kode.
Kode
{{ page.adx_copy | liquid }}