将实体字段类型显示为 Symfony2 中每个实体的某些属性的 table
Displaying an entity field type as table of some properties of each entity in Symfony2
我需要在两个实体之间建立单向 One-To-Many 关系。
为了让用户 select 我使用实体字段类型的关系:
$builder->add('selectedItems','entity',array(
'class'=>'MY\ExBundle\Entity\MyRow',
'multiple'=>true,
'expanded'=>true,
)
)
但是对于每个实体,我只有一个 checkbox
及其标签。
我需要将每个实体显示为一个 table 行,它的列是基础实体的一些属性(例如 price、count 等)以及 checkbox
以便用户可以看到有关实体的更多详细信息如果他想检查它们。
例如:
+---+-------+--------+--------------+
| | price | count | deliveryDate |
+---+-------+--------+--------------+
| X | 100 | 6 | 2015-01-02 |
+---+-------+--------+--------------+
| | 70 | 5 | 2015-02-03 |
+---+-------+--------+--------------+
我该怎么做?
我应该创建一个新的字段类型吗?如果是这样,我如何访问底层 child 实体?
或者我需要使用嵌入表单集合之类的东西?如果是这样,如何让 symfony 威胁它作为一个选择列表而不是新添加的条目。
编辑:
这是 MY\ExBundle\Entity\MyRow
实体:
/**
* MyRow
*
* @ORM\Table()
* @ORM\Entity(repositoryClass="ITW\BidBundle\Entity\MyRowRepository")
*/
class MyRow
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var integer
*
* @ORM\Column(name="count", type="integer")
*/
private $count;
/**
* @var integer
*
* @ORM\Column(name="price", type="integer")
*/
private $price;
/**
* @var \DateTime
*
* @ORM\Column(name="deliveryDate", type="date")
*/
private $deliveryDate;
/**
* @var string
*
* @ORM\Column(name="description", type="string", length=255,nullable=true)
*/
private $description;
}
编辑2:
我试图为此目的创建一个字段类型,这是我为此使用的模板:
{%- block tablechoice_widget -%}
<table {{ block('widget_container_attributes') }}>
<thead>
<th></th>
<th>price</th>
<th>count</th>
</thead>
<tbody>
{%- for child in form %}
<tr>
<td>{{- form_widget(child) -}}</td>
<td></td>
<td></td>
</tr>
{% endfor -%}
</tbody>
</table>
{%- endblock tablechoice_widget -%}
但我无法访问 childs (checkboxes
) 的基础实体 (MyRow
)。
在 twig 中,如果您使用该符号(例如)
{{ entity.child }}
但 entity
是您表单的一个字段,您将无法访问实际实体 object 但会以其形式表示(因此复选框或其他内容)
如果您想访问 "real" object(及其 child),您应该使用
{{ entity.vars.data }}
及其 child
{{ entity.vars.getChild }}
当然,您必须根据您的实际代码调整名称。
祝你好运!
我需要在两个实体之间建立单向 One-To-Many 关系。
为了让用户 select 我使用实体字段类型的关系:
$builder->add('selectedItems','entity',array(
'class'=>'MY\ExBundle\Entity\MyRow',
'multiple'=>true,
'expanded'=>true,
)
)
但是对于每个实体,我只有一个 checkbox
及其标签。
我需要将每个实体显示为一个 table 行,它的列是基础实体的一些属性(例如 price、count 等)以及 checkbox
以便用户可以看到有关实体的更多详细信息如果他想检查它们。
例如:
+---+-------+--------+--------------+
| | price | count | deliveryDate |
+---+-------+--------+--------------+
| X | 100 | 6 | 2015-01-02 |
+---+-------+--------+--------------+
| | 70 | 5 | 2015-02-03 |
+---+-------+--------+--------------+
我该怎么做?
我应该创建一个新的字段类型吗?如果是这样,我如何访问底层 child 实体?
或者我需要使用嵌入表单集合之类的东西?如果是这样,如何让 symfony 威胁它作为一个选择列表而不是新添加的条目。
编辑:
这是 MY\ExBundle\Entity\MyRow
实体:
/**
* MyRow
*
* @ORM\Table()
* @ORM\Entity(repositoryClass="ITW\BidBundle\Entity\MyRowRepository")
*/
class MyRow
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var integer
*
* @ORM\Column(name="count", type="integer")
*/
private $count;
/**
* @var integer
*
* @ORM\Column(name="price", type="integer")
*/
private $price;
/**
* @var \DateTime
*
* @ORM\Column(name="deliveryDate", type="date")
*/
private $deliveryDate;
/**
* @var string
*
* @ORM\Column(name="description", type="string", length=255,nullable=true)
*/
private $description;
}
编辑2: 我试图为此目的创建一个字段类型,这是我为此使用的模板:
{%- block tablechoice_widget -%}
<table {{ block('widget_container_attributes') }}>
<thead>
<th></th>
<th>price</th>
<th>count</th>
</thead>
<tbody>
{%- for child in form %}
<tr>
<td>{{- form_widget(child) -}}</td>
<td></td>
<td></td>
</tr>
{% endfor -%}
</tbody>
</table>
{%- endblock tablechoice_widget -%}
但我无法访问 childs (checkboxes
) 的基础实体 (MyRow
)。
在 twig 中,如果您使用该符号(例如)
{{ entity.child }}
但 entity
是您表单的一个字段,您将无法访问实际实体 object 但会以其形式表示(因此复选框或其他内容)
如果您想访问 "real" object(及其 child),您应该使用
{{ entity.vars.data }}
及其 child
{{ entity.vars.getChild }}
当然,您必须根据您的实际代码调整名称。
祝你好运!