我有一个链接到配方对象的表格。该配方对象具有配方类别。
修改配方时,除了添加新类别外,更新任何字段都将非常有用。
我的表格:
$builder
->add('recipeCategories', 'entity',array(
'multiple' => true,
'class' => 'AppBundle:FoodAnalytics\RecipeCategory',
'label' => 'Catégories',
'required' => false,
'attr'=>array(
'data-toggle'=>"tooltip",
'data-placement'=>"top",
'title'=>"Indiquez les catégories dans lesquelles enregistrer la recette pour un recherche future plus facile",
)))
这是我得到的:
exit(var_dump($request->request));
该请求确实有食谱
$recipeForm->handleRequest($request);
exit(var_dump($recipeForm->getData()->getRecipeCategories()->toArray()));
该表格确实有食谱
$formManager->getEntityManager()->persist($recipe);
exit(var_dump($recipe->getRecipeCategories()->toArray()));
食谱确实有类别
$formManager->getEntityManager()->flush($recipe);
exit(var_dump($formManager->getEntityManager()->getUnitOfWork()->getScheduledEntityInsertions()));
有无同花顺,我在这里得到空值
我正在运行symfony〜2.6.0和doctrine〜1.3,并将composer preferred-stable设置为true。
对我可以做些什么有什么想法?其他字段正确保留。我的实体通过以下方式链接:
/**
* @ORM\ManyToMany(targetEntity="\AppBundle\Entity\FoodAnalytics\Recipe", inversedBy="recipeCategories")
* @ORM\JoinTable(
* name="RecipeCategoryHasRecipe",
* joinColumns={@ORM\JoinColumn(name="recipeCategoryId", referencedColumnName="id", nullable=false)},
* inverseJoinColumns={@ORM\JoinColumn(name="recipeId", referencedColumnName="id", nullable=false)}
* )
*/
private $recipes;
我想到了!
我认为在表单中定义by_reference => false仅用于集合,但在这里也是这种情况。我必须添加以下代码:
/**
* Add recipeCategory
*
* @param RecipeCategory $recipeCategory
*
* @return Recipe
*/
public function addRecipeCategory(RecipeCategory $recipeCategory)
{
$recipeCategory->addRecipe($this); //makes the difference
$this->recipeCategories[] = $recipeCategory;
return $this;
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句