我有2个实体。Category
和 Article
具有以下关系:
Article
有 一 Category
. Category
可能有 许多 Article
.问题是 :
我想用这个表格添加新的类别。
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add('name', TextType::class)
->add('submit', SubmitType::class, [
'label' => 'Add a new category'
])
;
}
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults([
'data_class' => Category::class,
]);
}
下面是我输入一个错误的信息。绳子 字段名中的值。
Name Error This value should be of type array|IteratorAggregate.
我从来没有用过 ArrayCollection
的关系,但我试着改变了symfony中的 TextType::class
到 CollectionType::class
它给我一个白色的方块,我不能打任何东西。
在一个更通用的问题: 我怎样才能在表单中验证值而不出现错误。This value should be of type array|IteratorAggregate.
Category
/**
* @ORM\Id()
* @ORM\GeneratedValue()
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\Column(type="string", length=255)
* @Assert\Unique(message="Cette catégorie existe déjà")
*/
private $name;
/**
* @return mixed
*/
public function getId()
{
return $this->id;
}
/**
* @return mixed
*/
public function getName()
{
return $this->name;
}
/**
* @param $name
* @return Collection|null
*/
public function setName($name): ?Collection
{
return $this->name = $name;
}
文章
/**
* @ORM\Id()
* @ORM\GeneratedValue()
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\Column(type="text")
*/
private $title;
/**
* @ORM\Column(type="text")
*/
private $content;
/**
* @ORM\Column(type="datetime")
*/
private $createdAt;
/**
* @ORM\Column(type="string", nullable=true)
*/
private $image;
/**
* @ORM\Column(type="datetime", nullable=true)
*/
private $editedAt;
/**
* @ORM\ManyToOne(targetEntity="App\Entity\Category")
*/
private $category;