我对symfony和symfony表格很陌生。
我有一个带有EntityType的表单,如下所示:
->add('customer', EntityType::class, [
'label' => 'Kunde: ',
'class' => Customer::class,
'choice_label' => 'Name',
'query_builder' => function(EntityRepository $er) {
return $er->createQueryBuilder('c')
->select('CONCAT(c.firstname, " ", c.surname) AS Name');
}
])
但我现在得到错误/警告:
Warning: spl_object_hash() expects parameter 1 to be object, string given
客户实体:
/**
* @ORM\Entity(repositoryClass="App\Repository\CustomerRepository")
*/
class Customer
{
/**
* @ORM\Id
* @ORM\GeneratedValue
* @ORM\Column(type="integer")
*/
private $id;
/**
* @var string
*
* @ORM\Column(name="firstname", type="string", length=50, nullable=false)
*/
private $firstname;
/**
* @var string
*
* @ORM\Column(name="surname", type="string", length=50, nullable=false)
*/
private $surname;
...
非常感谢你的时间和帮助。
答案 0 :(得分:8)
你也可以简单地使用choice_label
E.g:
->add('customer', EntityType::class, [
'label' => 'Kunde: ',
'class' => Customer::class,
'choice_label' => function (Customer $customer) {
return $customer->getFirstname() . ' ' . $customer->getSurname();
// or better, move this logic to Customer, and return:
// return $customer->getFullname();
},
])
答案 1 :(得分:2)
您是否在客户实体中创建了__toString()
方法。
/**
* toString
*
* @return string
*/
public function __toString() {
return $this->getFirstname().' '.$this->getSurname();
}
然后,这样的事情应该足够了:
->add('customer')
如果客户与您的entityType相关,这应该足够了
答案 2 :(得分:2)
不确定这是否适用于 Symfony 4,但它适用于 symfony 5。这更像是 Yoshis 答案的扩展,而不是新答案。
如果您按照 Yoshi 的建议创建 getFullname()
函数,您可以执行以下操作。
Customer.php:
public function getFullname(): ?string {
return $this->firstname . ' ' . $this->surname;
}
然后在您的表单中:
->add('customer', EntityType::class, [
'label' => 'Kunde: ',
'class' => Customer::class,
'choice_label' => 'fullname'
])
向客户添加全名功能还允许您在树枝文件中使用全名。
例如
{{ customer.fullname }}