首先,这是我的数据库设计。
每个故事都与一个项目有关。
----------- --------------
| project | | story |
----------- --------------
| id | | id |
| name | | project_id |
----------- | name |
--------------
使用以下代码定义项目与故事之间的关系。
实体/ Project.php
class Project {
...
/**
* @ORM\OneToMany(targetEntity="Story", mappedBy="project")
*/
private $stories;
...
}
实体/ Story.php
class Story {
...
private $title;
/**
* @ORM\ManyToOne(targetEntity="Project", inversedBy="stories")
* @ORM\JoinColumn(name="project_id", referencedColumnName="id", nullable=FALSE)
*/
private $project;
...
}
我的控制器看起来像这样:
/**
* @Route("/story/create/project/{id}", name="storyCreate")
*/
public function createAction($id, Request $request) {
/* Get project by id */
$project = $this->getDoctrine()
->getRepository('AppBundle:Project')
->find($id);
/* Create new story instance and set project */
$story = new Story();
$story->setProject($project);
/* Generate the form and handle the request */
$form = $this->createForm(CreateStoryType::class, $story);
$form->handleRequest($request);
/* Form is submitted and valid */
if($form->isSubmitted() && $form->isValid()) {
/* Create the objects */
$em = $this->getDoctrine()->getManager();
$em->persist($story);
$em->flush();
}
$this->context['form'] = $form->createView();
return $this->render('project/create.html.twig', $this->context);
}
我也按照本指南创建了一个Project to ID转换器。
现在,在初始加载页面时,一切看起来都很完美。
我收到了一个表单,其中包含Project
和Title
输入文本框,其中Project
字段预先填充了网址中指示的当前项目。
提交后,Project
字段始终会获得This value should not be blank.
验证错误,即使它不为空。我做得对吗?我无法再访问$story->getProject()
,因为它在提交后设置为null
。
答案 0 :(得分:2)
好的,因为@ jbafford的评论我找到了问题。
我的数据转换器未在reverseTransform
方法中返回实体。