我正在使用Symfony 3 Forms进行构建,并且需要在表单中检索依赖于当前用户的集合,以便在下拉列表中呈现。
使用EntityType
我可以检索所有实体的列表,但我希望能够运行自定义查询,该查询仅检索与当前用户对象有关系的自定义查询。
我已经阅读了有关表单和EntityType的文档,并解释了自定义查询和提及作为参数传递集合的内容。但我无法找到关于如何在任何地方实现这一目标的说明。
理想情况下,我想传入我在Controller中策划的集合,传入User对象以在Form中运行查询,或以其他方式访问表单中的用户ID在。上运行查询。
有没有人找到类似的解决方案?
答案 0 :(得分:6)
你应该试试
传入User对象以在Form
中运行查询
在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'));
}
它会强制您通过user
选项,这样您就不会忘记它。
在控制器中它看起来像这样:
$this->createForm(SomeFormType::class, $underlyingObjectOrNull, array(
'user' => $this->getUser(),
));
建立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
},
));
请注意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()
));
}