Symfony -具有多个实体对象的表单

mwkjh3gx  于 2022-11-16  发布在  其他
关注(0)|答案(2)|浏览(167)

我正在运行Symfony 3.4 LTS,我有一个实体Attribute

<?php

class Attribute
{

    private $id;
    private $code;
    private $value;
    private $active;

    // My getters and setters

在数据库表下面:

我想在一个表单中得到所有code == 'productstatus'的行。

<?php

$attributes = $this->getDoctrine()->getRepository(Attribute::class)->findBy(['code' => 'productstatus']);
// $attributes contains array with 3 objects 'Attribute'
$form = $this->createFormBuilder($attributes);
$form->add('value', TextType::class);
$output = $form->getForm()->createView();

如果我转储()Twig中的$output变量:

...我无法循环显示3个字段的值。

{{ form_start(form) }}
{{ form_widget(form) }}
{{ form_end(form) }}

结果:

我的目标是允许用户在同一个表单(或多个表单,但在同一个页面中)中编辑特定属性的所有值。

5vf7fwbs

5vf7fwbs1#

我找到了解决办法:创建2个嵌套窗体并使用CollectionType。希望对您有所帮助。

<?php

// Controller

$attributes = $this->getDoctrine()->getRepository(Attribute::class)->findBy(['code' => 'productstatus']);
$form = $this->createForm(AttributeForm::class, ['attributes' => $attributes]);

// AttributeForm

$builder
    ->add('attributes', CollectionType::class, [
        'entry_type' => AttributeValueForm::class,
        'allow_add' => true,
        'by_reference' => false,
        'allow_delete' => true,
    ]);

// AttributeValueForm

$builder
    ->add('value', TextType::class, ['label' => false, 'required' => false])
    ->add('active', CheckboxType::class, ['label' => false, 'required' => false])

// Twig view

{{ form_start(form) }}
    {% for attribute in form.attributes.children %}
        <tr>
            <td>{{ form_widget(attribute.value) }}</td>
            <td>{{ form_widget(attribute.active) }}</td>
        </tr>
    {% endfor %}
{{ form_end(form) }}
oipij1gg

oipij1gg2#

您可以在AttributeType中使用if陈述式,如下例所示:

$builder
    ->add('entree', EntityType::class, array('class'=>'cantineBundle:plat',
  'choice_label'=>function($plat){
      if($plat->getType()=='Entree'&&$plat->getStatus()=="non reserve"){
           return $plat->getNomPlat();
      }
  },
  'multiple'=>false)
);

相关问题