4

只需将主题应用于表单字段很容易,例如:

{% form_theme form _self %}

{% block _product_name_widget %}
    {{ block('field_widget') }}
{% endblock %}

但是如果表单域是集合类型呢?例如: product['models'][1][comment,我不知道如何自定义它。(这可能是这里的第一个问题)

更新:此处的回答者:Symfony2:带有数据原型的集合表单字段类型

4

3 回答 3

5

从 Symfony 2.1 开始(它可能也适用于 2.0,但不确定)应用主题来收集你这样做:

假设我们有一个产品集合(我们有多个产品实体)

控制器:

    $repository = $this->getDoctrine()->getRepository('ExampleBundle:Product');
    $products = $repository->findAll();

    $productCollection = new Products;

    foreach ($products as $product) {
        $productCollection->getProducts()->add($product);
    }

    $collection = $this->createForm(new ProductsType, $productCollection);

    return $this->render('ExampleBundle:Default:index.html.twig', array(
        'collection' => $collection->createView()
            ));        

您的主题可能如下所示:

{% block _productsType_products_entry_name_row %}
    <div class="yourDivName">{{ block('form_widget') }}</div>
{% endblock %}
{% block _productsType_products_entry_description_row %}
    <div class="yourDivDescription">{{ block('form_widget') }}</div>
{% endblock %}

诀窍是使用“条目”,其中 twig 将为您完成对每一行和您指定的每个字段的上述更改

希望有帮助!

于 2012-09-12T11:03:41.980 回答
1

您可以使用覆盖 collection_widget 块:

{% block collection_widget %}
{% spaceless %}
    {% if prototype is defined %}
        {% set attr = attr|merge({'data-prototype': form_row(prototype) }) %}
    {% endif %}
    {{ block('form_widget') }}
{% endspaceless %}
{% endblock collection_widget %}

如果您想如何自定义表单集合类型,请尝试查看此产品包

于 2012-07-16T07:01:56.870 回答
0

您也可以通过引用这样的小部件来覆盖collection_widget单个字段的主题。

例如,如果“类别”是ProductType表单上的“集合”小部件,您可以这样做。

{% block _product_categories_widget %}
    {% for child in form %}
        {{- form_row(child) -}}
        <hr>
    {% endfor %}
{% endblock %}
于 2015-06-19T05:44:40.787 回答