Ответы:
В Twig нет хорошего способа сделать это. Однако это возможно с помощью фильтра слияния:
{% set arr = arr|merge({'element': 'value'}) %}
.
и []
очень похожи в Twig, и я ошибался. Я посмотрел и отредактировал свой ответ.
'element'
. Я нашел ответ @LivaX ниже. Так бы и было {% set arr = arr|merge({(key): 'value'}) %}
.
{{ UI.button({'type':'submit'}) }}
и все эти макросы используют | merge для установки параметров по умолчанию, так что в этом есть логическая необходимость ...
Я столкнулся с этой проблемой, но пытался создать целочисленные индексы вместо ассоциативного индекса, такого как «элемент».
Вам также необходимо защитить свой индексный ключ с ()
помощью фильтра слияния:
{% set arr = arr|merge({ (loop.index0): 'value'}) %}
Теперь вы можете добавить собственный индексный ключ, например ('element'~loop.index0)
Если требуется только инициализация:
{% set items = { 'apple': 'fruit', 'orange': 'fruit', 'peugeot': 'unknown' } %}
Я пробовал ответить @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_ ....
{% 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, но я разработал следующее:
$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')%}
Просто используйте это как {% 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 does not work, saying title is not defined
Некоторое время назад у меня была эта проблема. Представьте, что у вас есть такой массив:
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
. И, наконец, мы * вставляем ассоциативный элемент в левый или правый массив. Ассоциативный массив состоит из двух компонентов key
и value
. Чтобы ссылаться на ключ массива в 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 %}