Symfony 3:将变量传递给表单

时间:2017-03-29 11:29:13

标签: php forms symfony entities

我正在使用Symfony 3 Forms进行构建,并且需要在表单中检索依赖于当前用户的集合,以便在下拉列表中呈现。

使用EntityType我可以检索所有实体的列表,但我希望能够运行自定义查询,该查询仅检索与当前用户对象有关系的自定义查询。

我已经阅读了有关表单和EntityType的文档,并解释了自定义查询和提及作为参数传递集合的内容。但我无法找到关于如何在任何地方实现这一目标的说明。

理想情况下,我想传入我在Controller中策划的集合,传入User对象以在Form中运行查询,或以其他方式访问表单中的用户ID在。上运行查询。

有没有人找到类似的解决方案?

2 个答案:

答案 0 :(得分:6)

你应该试试

  

传入User对象以在Form

中运行查询
  1. options resolver中定义所需参数user

    public function configureOptions(OptionsResolver $resolver)
    {
        // ...
        $resolver->setRequired('user');
        // type validation - User instance or int, you can also pick just one.
        $resolver->setAllowedTypes('user', array(User::class, 'int'));
    }
    
  2. 它会强制您通过user选项,这样您就不会忘记它。

    1. 将用户实例或用户ID作为选项传递到表单中。
    2. 在控制器中它看起来像这样:

      $this->createForm(SomeFormType::class, $underlyingObjectOrNull, array(
          'user' => $this->getUser(),
      ));
      
      1. 建立custom query for EntityType字段:

        $user = $options['user'];
        $builder->add('someField', EntityType::class, array(
            'class' => 'AppBundle:SomeEntity',
            'query_builder' => function (EntityRepository $er) use($user) {
                return $er->createQueryBuilder('u')
                   //.. -> some method building the query builder
            },
        ));
        
      2. 请注意use($user)部分,它允许您在匿名函数内访问此变量。

答案 1 :(得分:1)

以下是将自定义集合传递到表单的方法。

例如:产品实体;

控制器内部

$form = $this->createForm(ProductType::class, $product, array('recommended_product' => $recommendedProduct));

在FormType中

 $builder
   ->add('recommended_product', EntityType::class, array(
            'class' => 'AppBundle\Entity\Product',
            'choices' => $options['recommended_product'],
            'choice_label' => function (Product $user) {
                return $user->getProduct();
            }
        ));

 public function configureOptions(OptionsResolver $resolver)
{
    $resolver->setDefaults(array(
        'data_class' => 'AppBundle\Entity\Product',
        'recommended_product' => array()
    ));
}
相关问题