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

下一篇: Jenkins email notification setup