简体   繁体   中英

How to define an array in twig

I need to display an image in twig based on a value that comes from controller. For example there in an image of a home that should appear if the value coming from the controller is (Home or home or renovation or Renovation or rent or Rent) and the list goes on.

At the moment what is am doing is as following

{% if goal == "house" or  goals == "House" or goal == "home" or  goals == "Home" %}
<img src="{{ asset('bundles/bundlename/images/house.jpg') }}">
{% endif %}

The list is pretty long and this is soon going to get out of hand. So I was thinking to simply create an array in twig and check if the value coming from controller exist on that array i have in twig to display an image.

You can define an array with {key: value} or [value1, value2] syntaxes. Read more about arrays and twig itself here .

You can do something like:

{% set images = {
    "house.jpg": ["house", "House", "home", "Home"]

    ... some more rules ...

} %}

{% for image, keys in images %}
    {% if goal in keys %}
        <img src="{{ asset('bundles/bundlename/images/' ~ image) }}">
    {% endif %}
{% endfor %}

Also you can simplify your code to {% if goal|lower in keys %} and define keys only in lower case if you always have to check to both cases.

Defining an Array in twig

{% set section = { foo:{ heading:"bar" } } %}

{{ section.foo.heading }}

bar //output



{% set section = { foo:"bar" } } %}

{{ section.foo }}

bar //output


{% set section = { foo:"bar", one:"two" } } %}

{{ section.one }}

two //output

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM