我无法弄清楚如何在symfony2中为实体类型设置默认值。我的代码看起来像这样:
$rewardChoice = $this->createFormBuilder($reward)
->add('reward_name', 'entity', array(
'class' => 'FuelFormBundle:Reward',
'property' => 'reward_name',
'data' => 2,
'query_builder' => function(EntityRepository $er){
return $er->createQueryBuilder('r')
->where('r.active = 1')
->groupBy('r.reward_id')
->orderBy('r.reward_name', 'DESC');
},
))
->getForm();
但是,您需要交出正在使用的对象才能使其正常工作。我的答案如下。
我发现了很多不同的答案,但他们都重新构建了表单的构建方式。这更容易。
答案 0 :(得分:9)
所以我找到了很多答案来使这项工作,但所有这些似乎重新构建了以另一种方式构建的形式,但是我发现设置对象的效果最好所以我想我会发布我的解决方案,任何人都跑再次进入这个问题。
这是控制器中的代码。
// this is setting up a controller and really isn't important
$dbController = $this->get('database_controller');
// this is getting the user id based on the hash passed by the url from the
// database controller
$user_id = $dbController->getUserIdByHash($hash);
// this is getting the Reward Entity. A lot of times you will see it written as
// $reward = new Reward however I am setting info into reward right away in this case
$reward = $dbController->getRewardByUserId($user_id);
$rewardChoice = $this->createFormBuilder($reward)
->add('reward_name', 'entity', array(
'class' => 'FuelFormBundle:Reward',
'property' => 'reward_name',
// I pass $reward to data to set the default data. Whatever you
// assign to $reward will set the default value.
'data' => $reward,
'query_builder' => function(EntityRepository $er){
return $er->createQueryBuilder('r')
->where('r.active = 1')
->groupBy('r.reward_id')
->orderBy('r.reward_name', 'DESC');
},
))
->getForm();
我希望这会让事情更清楚。我看到很多相同的问题,但没有这个解决方案。
答案 1 :(得分:2)
执行此操作的最佳方法是在创建表单之前设置奖励名称。例如:
$reward->setRewardName('your_relationship_reference_here');
$rewardChoice = $this->createFormBuilder($reward)
使用data
字段可能会导致问题。
答案 2 :(得分:2)
对于symfony 4,我们可以使用'placeholder'=>'选择一个选项'
->add('reward_name', EntityType::class, array(
'class' => Reward::class,
'choice_label' => 'name',
'placeholder' => 'Choose an option',
))
答案 3 :(得分:1)
初始化表单目标对象的值
B