我有一个问题,使用Symfony 2表单类型,我似乎无法掌握窍门。我有一个设备,应该归入一个类别。这很好用。我得到一个包含所有类别Id的选择框。
DeviceType.php:
->add('category', 'entity', array(
'placeholder' => 'Please choose a category',
'required' => true,
'class' => 'MSelectorBundle:Category',
'property' => 'id'))
然而,类别名称等存储在一个不同的实体中,这允许我用OneToMany关系将它们翻译成不同的语言,如下所示:
Category.php:
class Category
{
/**
* @var integer
*
* @ORM'Column(name="id", type="integer")
* @ORM'Id
* @ORM'GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var integer
*
* @ORM'Column(name="active", type="boolean")
*/
private $active;
/**
* @ORM'OneToMany(targetEntity="'M'SelectorBundle'Entity'CategoryTranslations", mappedBy="category", cascade={"persist", "remove"} ,orphanRemoval=true)
*/
protected $categoryTranslations;
现在,我不想显示非描述性的id,而是想用特定的语言显示类别名称,但我无法做到这一点。
CategoryTranslations.php:
/**
* CategoryTranslations
*
* @ORM'Table(name="categoryTranslations")
* @ORM'Entity
*/
class CategoryTranslations
{
/**
* @var integer
*
* @ORM'Column(name="id", type="integer", length=10)
* @ORM'Id
* @ORM'GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}
/**
* @var integer
*
* @ORM'Column(name="category_id", type="integer", length=10)
*/
private $category_id;
/**
* @var string
*
* @ORM'Column(name="lang", type="string", length=10)
*/
private $lang;
/**
* @var string
*
* @ORM'Column(name="name", type="string", length=300)
*/
private $name;
我尝试过查询生成器和数组集合,但一直未能解决这个问题。我是新来的,所以希望有人能给我指引正确的方向。非常感谢。
entity
字段不适合您所需的内容。我建议您使用collection
字段并将其传递给ChoiceList
。ChoiceList
构造函数接受两个数组,一个用于值,另一个用于标签。
您可能遇到的唯一问题是在表单提交之后,当您试图将值映射回实体时。只需确保将实体ID作为值传递即可。
将'property' => 'id'
更改为'property' => 'name'
还需要在实体类中实现getter和setter