在 symfony 2.0 中,如何在表单中使用一对一关联创建下拉列表?请大家举个例子好吗?
2 回答
我将尝试以我理解的方式回答您的问题。假设我有一个Faculty
绑定到单个对象的University
对象。因此,在用于创建或编辑教师的表单中,我显示了数据库中所有大学的组合框,用户从中选择一个。有一种特殊的 Symfony 字段类型可以做到这一点:实体类型。下面是buildForm
我在FacultyType
用于创建学院表单的对象中使用的方法的代码:
// Application\AcmeBundle\Form\Type\FacultyType
public function buildForm(FormBuilder $builder, array $options)
{
$builder->add('name');
$builder->add('university', 'entity', array(
// The class of the entity used as a combo box item
'class' => 'AcmeBundle:University',
// The property of the entity displaying the entity as text
'property' => 'name',
// The query builder used to populate the combo box, accepts
// a QueryBuilder object or a \Closure like below
'query_builder' => function(EntityRepository $repository) {
// This will return a query builder selecting all universities
return $repository->createQueryBuilder('u');
}
));
}
注意:实体字段类型还有其他属性可以设置,我邀请您查看此页面以获取更多信息。
渲染后,这将显示一个组合框,其中包含我在数据库中设置的所有大学。当用户保存表单时,大学选择被分配给通过设置器绑定到表单的教师对象。您可能会呈现一个下拉列表而不是组合框。如果您需要选择多个实体,'multiple'
字段类型实体的选项可能很有用。
话虽如此,我展示的示例不是一对一关系,而是Faculty
对象的多对一和对象的一对多University
。一对一关系更像是 aUniversity
具有唯一性的关系Address
。在这种情况下,组合框不会有用,因为大学只能有一个地址,因此子表单会更合适。如果它有很多地址,那么它就变成了一对多的关系,就像大学和学院之间的关系一样。
不确定这是否会正确回答您的问题,但我希望它能引导您找到最终解决方案。
问候, 马特
您需要使用 Symfony2 中的实体字段类型。一个很好的例子可以在http://symfony.com/doc/current/reference/forms/types/entity.html找到