打字错误3 | Extbase / Fluid - 如何从域对象/数据库中填充 <f:form.select.optgroup>?
TYPO3 | Extbase / Fluid - How can I fill <f:form.select.optgroup> from a domain object / database?
嗨,我正在为 苦苦挣扎
我需要用选项组填充值,但根据手册,我只能找到如何手动创建 optgroup。
有人知道用对象/数据库中的值填充 select 的方法吗?
这个 select 工作正常,但显然没有创建选项组
现在我该如何修改视图,使其变成这样:
<select class="form-control select2-multiple select2-multiple-max3" name="position[]">
<optgroup label="Geschäftsführung / Management">
<option value="1">Geschäftsführer KMU (Bereich Handel / Dienstleistung)</option>
<option value="2">Geschäftsführer Großunternehmen (Bereich Handel / Dienstleistung)</option>
<option value="3">Geschäftsführer KMU (Bereich Produktion)</option>
</optgroup>
<optgroup label="Steuern / Revision / Treuhand">
...
对象 {positionen} 的内容如下所示:
(Screenshot of fluid debug output)
您将需要自己的分组逻辑,方法是在您的控制器中准备分组或使用 <f:groupedFor>
:
<f:select property="position">
<f:groupedFor
each="{positions}"
as="areaPositions"
groupBy="area"
groupKey="area"
>
<f:form.select.optgroup label="{area.title}">
<f:for each="{areaPositions}" as="position">
<f:form.select.option value="{position.uid}">
{position.title}
</f:form.select.option>
</f:for>
</f:form.select.optgroup>
</f:groupedFor>
</f:select>
这里假定您已经加载了所有可能的 positions
(例如来自 PositionRepository
)并将其传递给模板。每个位置应该有一个相关的 area
(1:1),每个区域应该有一个 title
。这样您就可以按位置 area
对位置进行分组,并使用区域 title
作为选项组标签。
之后每个区域的所有位置都呈现为 select 选项,假设每个位置都有 title
。
嗨,我正在为
有人知道用对象/数据库中的值填充 select 的方法吗?
这个 select 工作正常,但显然没有创建选项组
现在我该如何修改视图,使其变成这样:
<select class="form-control select2-multiple select2-multiple-max3" name="position[]">
<optgroup label="Geschäftsführung / Management">
<option value="1">Geschäftsführer KMU (Bereich Handel / Dienstleistung)</option>
<option value="2">Geschäftsführer Großunternehmen (Bereich Handel / Dienstleistung)</option>
<option value="3">Geschäftsführer KMU (Bereich Produktion)</option>
</optgroup>
<optgroup label="Steuern / Revision / Treuhand">
...
对象 {positionen} 的内容如下所示: (Screenshot of fluid debug output)
您将需要自己的分组逻辑,方法是在您的控制器中准备分组或使用 <f:groupedFor>
:
<f:select property="position">
<f:groupedFor
each="{positions}"
as="areaPositions"
groupBy="area"
groupKey="area"
>
<f:form.select.optgroup label="{area.title}">
<f:for each="{areaPositions}" as="position">
<f:form.select.option value="{position.uid}">
{position.title}
</f:form.select.option>
</f:for>
</f:form.select.optgroup>
</f:groupedFor>
</f:select>
这里假定您已经加载了所有可能的 positions
(例如来自 PositionRepository
)并将其传递给模板。每个位置应该有一个相关的 area
(1:1),每个区域应该有一个 title
。这样您就可以按位置 area
对位置进行分组,并使用区域 title
作为选项组标签。
之后每个区域的所有位置都呈现为 select 选项,假设每个位置都有 title
。