从Twig设置数组元素

时间:2012-02-24 14:40:22

标签: php twig

如何从Twig中设置已存在数组的成员?

我尝试了下一步:

{% set arr['element'] = 'value' %}

但我收到以下错误:

  

值“[”(“语句块结束”)的意外标记“标点符号”   预期)... ...

11 个答案:

答案 0 :(得分:191)

在Twig中没有很好的办法。但是,可以使用合并过滤器:

{% set arr = arr|merge({'element': 'value'}) %}

答案 1 :(得分:73)

我遇到了这个问题但是试图创建整数索引而不是像'element'那样的关联索引。

您还需要使用合并过滤器()来保护索引键:

{% set arr = arr|merge({ (loop.index0): 'value'}) %} 

您现在可以添加自定义索引键,例如('element'~loop.index0)

答案 2 :(得分:16)

如果初始化只需要:

{% set items = { 'apple': 'fruit', 'orange': 'fruit', 'peugeot': 'unknown' } %}

答案 3 :(得分:2)

只需使用{% set arr={'key':'value'} %}(在':'后面没有空格),就可以了。但是,当我使用'for'来制作一个数组时,它无法在for区域内工作。

          {% for group in user.groups %}
            {% set foo={'loop.index0':'group.id'} %}
            {% set title={'loop.index0':'group.title'} %}
            {{ title }} //it work 
          {% else %}
            {% set foo={'0':'-1'} %}
            {% set title={'0':'未分组'} %}
          {% endfor %}
            {{ title }}  //it not work, say title is not defined

感谢您的关注。 (英语不好,对不起!)

答案 4 :(得分:2)

{% set links = {} %}

{# Use our array to wrap up our links. #}
{% for item in items %}
  {% set links = links|merge({ (loop.index0) : {'url': item.content['#url'].getUri(), 'text': item.content['#title']} }) %}
{% endfor %}

{%
set linkList = {
  'title': label,
  'links': links
}
%}

{% include '<to twig file>/link-list.twig'%}

感谢这个帖子 - 我也能用(loop.index0)创建一个数组并发送给twig。

答案 5 :(得分:1)

我已经尝试了@LivaX的答案,但它不起作用,合并一个数字键,数字键不起作用(https://github.com/twigphp/Twig/issues/789)。

仅当键是字符串

时才会起作用

我所做的是从初始表(temp)重新创建另一个表(t)并将键设为字符串,例如:

{% for key , value in t%}
{% set temp= temp|merge({(key~'_'):value}) %}
{% endfor %}

t键:0,1,2 ..

temp键:0_,1_,2_ ....

答案 6 :(得分:1)

我发现这个问题非常烦人,我的解决方案可能是正统的,不符合Twig哲学,但我开发了以下内容:

$function = new Twig_Function('set_element', function ($data, $key, $value) {
    // Assign value to $data[$key]
    if (!is_array($data)) {
        return $data;
    }
    $data[$key] = $value;
    return $data;
});
$twig->addFunction($function);

可以按如下方式使用:

{%set arr = set_element(arr,'element','value')%}

答案 7 :(得分:1)

添加我的答案,以防有人需要在 merge 不起作用时更新数组,因为它只是附加到数组的末尾,而不是提供更改现有值的能力。

假设您有一个数组 words_array,如下所示:

Object {
 0: "First word"
 1: "Second word"
 2: "Third word"
}

为了更新"Second word",您可以执行以下操作:

{% set words_array = {(1): 'New word'} + words_array %}

结果数组为:

Object {
 0: "First word"
 1: "New word"
 2: "Third word"
}

如果您使用循环并使用 loop.index0 变量,则可以更进一步:

{% for word in words_array %}
  {% if word == 'Second word' %}
    {% set words_array = {(loop.index0): 'New word'} + words_array %}
  {% endif %}
{% endfor %}

答案 8 :(得分:0)

我有一个多维数组。我能找到的唯一解决方案是创建一个新的临时数组并更新/添加这些信息,这些信息进一步传递给另一个twig函数。

答案 9 :(得分:0)

我前一段时间有这个问题。假设您有一个像这样的数组:

data = {
    'user': 'admin',
    'password': 'admin1234',
    'role': 'admin',
    'group': 'root',
    'profile': 'admin',
    'control': 'all',
    'level': 1,
    'session': '#DFSFASADASD02',
    'pre_oa': 'PRE-OA',
    'hepa_oa': 'HEPA-OA',
    'pre_ra': 'HEPA-RA',
    'hepa_ra': 'HEPA-RA',
    'deodor_ra': 'DEODOR-RA'
}

因此,您想在两行中显示此数据,但是从该列表中删除密码。为此,使用slice过滤器可以很容易地分成2个数组。但是,我们必须删除密码。因此,我正在使用此代码段。想法是将所有小于data元素大小除以2的元素放入其中。要计算此值,我们使用过滤器length。现在,要获取当前元素的索引,我们使用loop.index。最后,我们将一个关联元素推入左或右数组。关联数组具有两个成分keyvalue。要在twit中引用数组键,我们需要操作符(),然后使用merge过滤器将数组推入数组,如下所示{% set left_list = left_list|merge({ (key): value }) %}

这是完整的解决方案。

{% set left_list = {} %}
{% set right_list = {} %}
{% set limit = data|length // 2 %}
{% for key, value in data|cast_to_array %}
{% if key != 'password' %}
{% if loop.index <= limit %}
{% set left_list = left_list|merge({ (key): value }) %}
{% else %}
{% set right_list = right_list|merge({ (key): value }) %}
{% endif %}
{% endif %}
{% endfor %}
{% for key, value in left_list %}
<p>
<label for="{{key}}">{{key}}</label>
<input type="text" name="{{key}}" id="{{key}}" value="{{value}}"
       class="text ui-widget-content ui-corner-all">
</p>
{% endfor %}

答案 10 :(得分:0)

您还可以使用以下语法:

{% set myArray = myArray + myArray2 %}