我有一个表单构建器,它来自问题实体:
class Question
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @ORM\Column(type="string", length=255, name="question")
* @var string $question
*/
protected $question;
/**
* @ORM\Column(type="string", length=255, name="answer1")
* @var string $answer1
*/
protected $answer1;
/**
* @ORM\Column(type="string", length=255, name="answer2")
* @var string $answer2
*/
protected $answer2;
/**
* @ORM\Column(type="string", length=255, name="answer3")
* @var string $answer3
*/
protected $answer3;
/**
* @ORM\Column(type="integer", name="correct_answer")
* @var int $correctAnswer
*/
protected $correctAnswer;
/**
* @ORM\Column(type="datetime", name="post_date")
*/
protected $postDate;
/....
现在构建器看起来像这样:
$question = new Question();
$form = $this->createFormBuilder($question)
->add('id', HiddenType::class, array(
'data' => 0,
'attr' => array(
'class' => 'question-form__id'
)
)
)
->add('question', TextType::class, array('label' => 'Pytanie', 'required' => true))
->add('answer1', TextType::class, array('label' => 'Odpowiedź 1', 'required' => true))
->add('answer2', TextType::class, array('label' => 'Odpowiedź 2', 'required' => true))
->add('answer3', TextType::class, array('label' => 'Odpowiedź 3', 'required' => true))
->add('correctAnswer', ChoiceType::class, array(
'label' => 'Poprawna odpowieź',
'choices' => array(
'Pierwsza' => 1,
'Druga' => 2,
'Trzecia' => 3
)
))
->add('save', SubmitType::class, array(
'label' => 'Dodaj Pytanie',
'attr' => array(
'class' => 'btn btn-primary btn--add-question'
)
))
->getForm();
id将数据设置为0的原因是因为其中的值将形成一个新问题(if id==0
)或编辑当前问题(else
)。
问题是,在提交表格后我
无法确定属性“id”的访问类型
使用exit;
时,$form->handleRequest($request);
有趣的是,如果我将实体id
设置为 public ,则handleRequest工作正常。
我们都知道将id作为公共并不是一个好主意。
所以我的问题是如何避免错误而不必做有史以来最糟糕的做法?
编辑:将id
值设置为私有会导致同样的错误
答案 0 :(得分:5)
你可以为$ id添加一个setter,就像任何其他属性的setter一样