我在两个实体 A 和 B 之间建立了多对多关系。
所以在添加表单时,为了将entityA
添加到entityB
,我正在执行以下操作:
$builder
->add('entityAs', 'entity', array(
'class' => 'xxxBundle:EntityA',
'property' => 'name',
'multiple' => true,
));}
一切都很好。
但是根据 entityA 的字段类型,有时我想将“multiple”设置为 false,所以我正在执行以下操作:
if($type=='a'){
$builder
->add('entityAs', 'entity', array(
'class' => 'xxxBundle:entityA',
'property' => 'name',
'multiple' => true,
));}
else {
$builder
->add('entityAs', 'entity', array(
'class' => 'xxxBundle:entityA',
'property' => 'name',
'multiple' => false,
));
}
这给了我以下错误:
Catchable Fatal Error: Argument 1 passed to Doctrine\Common\Collections\ArrayCollection::__construct() must be an array, object given, called in C:\wamp\www\Symfony\vendor\doctrine\orm\lib\Doctrine\ORM\UnitOfWork.php on line 519 and defined in C:\wamp\www\Symfony\vendor\doctrine\common\lib\Doctrine\Common\Collections\ArrayCollection.php line 48
谁能帮帮我?
最佳答案
在 EntityA 中,你有这样的东西,对吧?
public function setEntitiesB($data)
{
$this->entitiesB = $data ;
}
现在因为您还可以接收单个值而不是值数组,所以您需要这样的东西:
public function setEntitiesB($data)
{
if ( is_array($data) ) {
$this->entitiesB = $data ;
} else {
$this->entitiesB->clear() ;
$this->entitiesB->add($data) ;
}
}
关于php - 以多对多关系 symfony2 的形式设置多个 ='false',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16539244/