Symfony Twig为一个集合定制一个Individual字段
在文档中,Symfony中有一种基于widget的名称/ ID自定义Individual字段的方法。
{% form_theme form _self %}
{% block _product_name_widget %}
<div class="text_widget">
{{ block('field_widget') }}
</div>
{% endblock %}
{{ form_widget(form.name) }}
这里,_product_name_widget片段定义用于id为product_name(且name是product [name])的字段的模板。
这适用于普通小部件,但不适用于小部件位于集合内部的情况。 由于额外的列。 喜欢这个:
name="productbundle_product_type[foobar][1][value]" id="productbundle_product_type_foobar_1_value"
在集合中制作Twig自定义工作的方法是什么?
我以为这样的事情,但这不起作用:
{% for db in edit_form.list %}
{% block _productbundle_product_type_foobar_{{ db.name }}_widget %}
<div class="text_widget">
{{ block('field_widget') }}
</div>
{% endblock %}
{% endfor %}
即使以下不起作用:
{% _productbundle_product_type_foobar_1_value_widget %}
有什么办法让它工作?
我几天前正在做一个项目,遇到了这个问题 - 我找到的解决方案是一对看起来像这样的块(剥离了项目特定的代码):
{# Collection markup #}
{% block my_collection_widget %}
{# Customise collection row prototype for allow_add #}
{% if prototype is defined %}
{% set data_prototype = block('my_collection_item_widget') %}
<div id="my_prototype" data-prototype="{{ data_prototype }}" style="display: none"></div>
{% endif %}
{% for prototype in form %}
{{ block('my_collection_item_widget') }}
{% endfor %}
{% endblock my_collection_widget %}
{# Collection row markup #}
{% block my_collection_item_widget %}
{# Collection contains simple, single type #}
{{ form_errors(prototype) }}
{{ form_label(prototype) }}
{{ form_widget(prototype) }}
{# OR #}
{# Collection contains a compound type, render child types independantly #}
{{ form_errors(prototype.inner_widget) }}
{{ form_label(prototype.inner_widget) }}
{{ form_widget(prototype.inner_widget) }}
{% endblock my_collection_item_widget %}
链接地址: http://www.djcxy.com/p/14287.html
上一篇: Symfony Twig customize an Individual field for a collection