在symfony 2.0中,如何使用表单中的一对一关联创建下拉列表?你们能举好榜样吗?
我将尝试以我理解的方式回答您的问题.假设我有一个Faculty对象绑定到一个University对象.因此,在用于创建或编辑教师的表单中,我在数据库中显示所有大学的组合框,并且用户在其中选择一个.有一个特殊的Symfony字段类型就是这样:实体类型.下面是我在用于创建教师表单的FacultyType对象中使用的buildForm方法的代码:
// 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'); } )); }
注意:可以为实体字段类型设置其他属性,我邀请您查看此page以获取有关它的更多信息.
渲染,这将显示我在数据库中设置的所有大学的组合框.当用户保存表单时,大学选择的是通过设置器分配给绑定到表单的教师对象.你可能会渲染一个下拉列表而不是一个组合框.如果需要选择多个实体,则字段类型实体的“多个”选项可能很有用.
话虽这么说,我展示的例子不是一对一的关系,而是Faculty对象的多对一和大学对象的一对多关系.一对一关系更像是大学拥有唯一地址的关系.在这种情况下,组合框将没有用,因为大学只能有一个地址,因此子表单更合适.如果它有许多地址,那么它就变成了一对多的关系,就像大学和它的院系之间的关系一样.
不确定这是否能正确回答您的问题,但我希望它会引导您找到最终解决方案.
问候,马特