只需将主题应用于表单字段很容易,例如:
{% form_theme form _self %}
{% block _product_name_widget %}
{{ block('field_widget') }}
{% endblock %}
但是如果表单域是集合类型呢?例如: product['models'][1][comment
,我不知道如何自定义它。(这可能是这里的第一个问题)
更新:此处的回答者:Symfony2:带有数据原型的集合表单字段类型
只需将主题应用于表单字段很容易,例如:
{% form_theme form _self %}
{% block _product_name_widget %}
{{ block('field_widget') }}
{% endblock %}
但是如果表单域是集合类型呢?例如: product['models'][1][comment
,我不知道如何自定义它。(这可能是这里的第一个问题)
更新:此处的回答者:Symfony2:带有数据原型的集合表单字段类型
从 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 将为您完成对每一行和您指定的每个字段的上述更改
希望有帮助!
您可以使用覆盖 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 %}
如果您想如何自定义表单集合类型,请尝试查看此产品包
您也可以通过引用这样的小部件来覆盖collection_widget
单个字段的主题。
例如,如果“类别”是ProductType
表单上的“集合”小部件,您可以这样做。
{% block _product_categories_widget %}
{% for child in form %}
{{- form_row(child) -}}
<hr>
{% endfor %}
{% endblock %}