gpt4 book ai didi

symfony - 如何在表单中列出实体

转载 作者:行者123 更新时间:2023-12-01 11:23:53 25 4
gpt4 key购买 nike

我有一个实体 Hall哪个可以欢迎另一个hall (subhall),或 stand .

我被 hall 困住了形式(或者至少这是我认为需要编辑的内容)。
我不知道如何让它显示 <select>所有 hallparent=0我还需要一个默认选项,它是空白的 0作为值(value)

这是我的文件:

大厅实体:

<?php

namespace SalonBundle\Entity;
use Doctrine\ORM\Mapping as ORM;

/**
* Hall
*
* @ORM\Table(name="hall")
* @ORM\Entity(repositoryClass="SalonBundle\Repository\HallRepository")
*/
class Hall {
/**
* @var int
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $idHall;

/**
* @var string
* @ORM\Column(name="name", type="string", length=255)
*/
private $name;

/**
* @var integer
* @ORM\Column(name="parent", type="integer", options={"default":0})
*/
private $parent;

/**
* @var
* @ORM\OneToMany(targetEntity="SalonBundle\Entity\Stand", mappedBy="hall")
*/
private $stand;

public function __construct()
{
$this->stand = new \Doctrine\Common\Collections\ArrayCollection();
}

/**
* Get idHall
* @return integer
*/
public function getIdHall()
{
return $this->idHall;
}

/**
* Set name
* @param string $name
* @return Hall
*/
public function setName($name)
{
$this->name = $name;

return $this;
}

/**
* Get name
* @return string
*/
public function getName()
{
return $this->name;
}

/**
* Set parent
* @param integer $parent
* @return Hall
*/
public function setParent($parent)
{
$this->parent = $parent;

return $this;
}

/**
* Get parent
* @return string
*/
public function getParent()
{
return $this->parent;
}

/**
* Add stand
* @param \SalonBundle\Entity\Stand $stand
* @return Hall
*/
public function addStand(\SalonBundle\Entity\Stand $stand)
{
$this->stand[] = $stand;

return $this;
}

/**
* Remove stand
* @param \SalonBundle\Entity\Stand $stand
*/
public function removeStand(\SalonBundle\Entity\Stand $stand)
{
$this->stand->removeElement($stand);
}

/**
* Get stand
* @return \Doctrine\Common\Collections\Collection
*/
public function getStand()
{
return $this->stand;
}

/**
* toString
* @return string
*/
public function __toString() {
return $this->getName();
}
}

大厅形式:
<?php

namespace SalonBundle\Form;

use SalonBundle\Entity\Hall;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;

class HallType extends AbstractType
{
/**
* @param FormBuilderInterface $builder
* @param array $options
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add('name')
->add('parent') // Need to complete this part
;
}

/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'SalonBundle\Entity\Hall'
));
}
}

我应该如何进行?

最佳答案

使用 'query_builder' 选项,您可以过滤实体:

http://symfony.com/doc/current/reference/forms/types/entity.html#ref-form-entity-query-builder

$builder->add('users', EntityType::class, array(
'class' => 'AppBundle:User',
'query_builder' => function (EntityRepository $er) {
return $er->createQueryBuilder('u')
->orderBy('u.username', 'ASC');
},
'choice_label' => 'username',
));

关于symfony - 如何在表单中列出实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39370636/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com