3

我在使用嵌入集合表单时遇到问题,因为我想过滤给定集合上显示的数据。IE

<?php
Class Parent
{
    ... some attributes ...

    /**
     * @ORM\OneToMany(targetEntity="Child", mappedBy="parent", cascade={"all"})
     */
     private $children;

    ... some setters & getters ...

}

Class Child
{
    private $attribute1;

    private $attribute2;

    /**
     * @ORM\ManyToOne(targetEntity="Parent", inversedBy="children")
     * @ORM\JoinColumn(name="parent_id", referencedColumnName="id")
     */
     private $parent;

     ... some setters & getters ...
}

然后我使用以下方法构建表单:

class ParentChildType extends AbstractType
{
    public function buildForm(FormBuilder $builder, array $options)
    {
        $builder
        ->add('children', 'collection', array(
            'type' => ChildrenType(),
            'allow_add' => true,
        ));
    }
}
...
On controller:

    $parent = $this->getDoctrine()->getEntityManager()->getRepository('AcmeBundle:Parent')->find( $id );
    $forms = $this->createForm( new ParentChildType(), $parent)->createView();

    and then..

    return array('forms' => $forms->crateView());

我的问题是当我想按模型类和/或模型类过滤集合$attribute1时。$attribute2Child

有一种方法可以按此集合表单的条件进行过滤吗?

4

2 回答 2

4

似乎我必须在使用 CreateQuery 之前过滤对象,然后使用这个过滤的对象创建表单。像这样:

$parent = $this->getDoctrine()->getEntityManager()->createQuery("
            SELECT p, c 
            FROM AcmeBundle:Parent p
            JOIN p.children c
            WHERE c.attribute1 = :attr1
              AND c.attribute2 = :attr2
           ")
           ->setParameter('attr1', <some_value>)
           ->setParameter('attr2', <some_value>)
           ->getOneOrNullResult();
$forms = $this->createForm( new ParentChildType(), $parent)->createView();
....
return array('forms' => $form->createView());           
于 2012-05-03T17:03:35.677 回答
0

我指出你正确的方向(我希望):

http://www.craftitonline.com/2011/08/symfony2-ajax-form-republish/

本文处理字段依赖关系。例如,当您选择一个国家/地区时,您将拥有属于该国家/地区的城镇出现在列表中。

看起来它看起来像你的问题

于 2012-05-03T11:59:37.710 回答