我实际上正在学习Symfony2,我遇到了问题。我在电影和演员之间有很多关系。
我创建了一个用于制作新电影的表单。在这种形式中,我有一个选定的输入来选择演员,但是当我选择了很多演员时,表格会产生一个错误“这个值不应该是空白的”。当我在actor类中删除我的断言时,我没有这个错误。 为什么我的表单检查我的actor类中的断言?
/*
* MOVIE CLASS
*
*/
class Movie
{
//...
/**
* @ORM\ManyToMany(targetEntity="Actor", inversedBy="movies")
* @ORM\JoinTable(name="movie_actor")
*/
protected $actors;
}
/*
* ACTOR CLASS
*
*/
class Actor
{
/**
* @ORM\Column(type="string", length="255")
* @Assert\NotBlank()
* @Assert\MinLength(3)
*/
protected $firstName;
/**
* @ORM\Column(type="string", length="255")
* @Assert\NotBlank()
* @Assert\MinLength(3)
*/
protected $lastName;
/**
* @ORM\Column(type="date", nullable = true)
*/
protected $birthday;
/**
* @ORM\Column(type="boolean")
* @Assert\NotBlank()
*/
protected $sexe;
/**
* @ORM\ManyToMany(targetEntity="Movie", mappedBy="actors")
* @Assert\NotNull()
*/
protected $movies;
}
/**
*
* MOVIE FORM
*/
class MovieType extends AbstractType
{
public function buildForm(FormBuilder $builder, array $options)
{
$builder
->add('title')
->add('description')
->add('category')
->add('actors', 'entity',
array(
'class' => 'MyAppFilmothequeBundle:Actor',
'query_builder' => function(EntityRepository $er)
{
return $er->createQueryBuilder('a')->orderBy('a.firstName', 'ASC');
},
'multiple' => true
))
->add('user')
;
}
public function getDefaultOptions(array $options)
{
return array(
'data_class' => 'MyApp\FilmothequeBundle\Entity\Movie');
}
public function getName()
{
return 'movie';
}
}
答案 0 :(得分:0)
通过向类添加一组规则(称为约束)来完成验证。因此,您的表单会查看您在相关类中放入的断言,以检查提交的数据是否有效。查看Forms章节。
还有一件事:默认情况下,实体字段为"required" option设置为“true”。如果你真的想要它,只需将其设置为false。