Yoo*_*oot 9 database formbuilder symfony
我正在构建一个包含名为"category"的字段的表单,我需要一个选项列表来执行此操作,但我不知道如何使用存储在数据库中的几个类别填充此选项列表.
public function buildForm(FormBuilder $builder, array $options) {
$builder -> add('item', 'text', array('label' => 'Item'));
$builder -> add('category', 'choice', array(
'choices' => ???,
'label' => 'Category'
));
}
Run Code Online (Sandbox Code Playgroud)
如何从数据库中获取类别并使用它们来构建表单?(似乎无法访问$ this-> getDoctrine - > ...在这个类中).
hac*_*k25 15
使用类型entity而不是choice
$builder
->add('entity_property', 'entity', array(
'class' => 'Namespace\\To\\Entity',
'query_builder' => function(EntityRepository $repository) {
return $repository->createQueryBuilder('q')
->where('q.a_field = yourvalue');
}
));
Run Code Online (Sandbox Code Playgroud)
编辑:
在查询中使用自定义参数的两种方法.在这两种情况下,参数都是从外部注入的,因此您的FormType不需要对会话或请求对象或其他任何内容的任何引用.
1-将所需参数传递给构造函数
class TaskType extends AbstractType
{
private $custom_value;
public function __construct($custom_value) {
$this->custom_value = $custom_value;
}
// ...
}
Run Code Online (Sandbox Code Playgroud)
在buildForm()你的必须将值复制到局部变量并使其可用于query_builder回调:
public function buildForm(/*...*/) {
$my_custom_value = $this->custom_value;
// ...
'query_builder' => function(EntityRepository $repository) use ($my_custom_value) {
return $repository->createQueryBuilder('q')
->where('q.a_field = :my_custom_value')
->setParameter('my_custom_value', $my_custom_value);
}
// ...
}
Run Code Online (Sandbox Code Playgroud)
2-使用方法的$options参数buildForm.
首先,您必须通过覆盖来定义默认值getDefaultOptions:
public function getDefaultOptions(array $options)
{
return array(
'my_custom_value' => 'defaultvalue'
);
}
Run Code Online (Sandbox Code Playgroud)
然后,您可以在createForm方法的第三个参数中从控制器传递它.
$this->createForm(new YourFormType(), $entity, array('my_custom_value' => 'custom_value'));
Run Code Online (Sandbox Code Playgroud)
现在可以通过$optionsyouru buildForm方法的参数获得该值.如上所述将其传递给回调.