我正在使用优秀的DCE扩展,并希望使用每个Child的字段通过Child-DCE在Container中循环两次。
在伪代码中如下所示:容器模板:
<div id="foo">
<f:for each="{dces}" as="dce">
{dce.fields.title}
</f:for>
</div>
<div id="bar">
<f:for each="{dces}" as="dce">
{dce.fields.bla}
</f:for></div>我该怎么做呢?
发布于 2017-08-19 19:47:59
我已经用Viewhelper解决了这个问题:
class DcevalViewHelper extends \TYPO3\CMS\Fluid\Core\ViewHelper\AbstractViewHelper {
/**
* @param ArminVieweg\Dce\Domain\Model\Dce object
*
* @return array
*
*/
public function render($dce) {
$contentObject = $dce->getContentObject();
$temp = GeneralUtility::xml2array($contentObject['pi_flexform']);
$temp = $temp['data']['sheet.tabGeneral']['lDEF'];
foreach($temp as $key=>$val) {
preg_replace( "/\r|\n/", "", $val['vDEF'] );
$dcedata[substr($key,9)]=$val['vDEF'];
}
$dcedata['uid']=$contentObject['uid'];
return $dcedata;
}
}在Containertemplate中(不需要子模板)
{namespace dce=ArminVieweg\Dce\ViewHelpers}
{namespace tom=Mediagmbh\Tomediavh\ViewHelpers}
<f:layout name="DefaultContainer" />
<f:section name="main">
<div id="foo">
<ul>
<f:for each="{dces}" as="dce">
<f:alias map="{field:'{tom:Dceval(dce:dce)}'}">
<li>{field.header}</li>
</f:alias>
</f:for>
</ul>
</div
<div id="bar">
<f:for each="{dces}" as="dce">
<f:alias map="{field:'{tom:Dceval(dce:dce)}'}">
<div><f:format.raw>{field.text}</f:format.raw></div>
</f:alias>
</f:for>
</div>
</div>
</f:section>发布于 2021-02-24 00:54:44
在DCE容器定义中,只需使用
<div id="foo">
<f:for each="{dces}" as="dce">
{dce.get.title}
</f:for>
</div>
<div id="bar">
<f:for each="{dces}" as="dce">
{dce.get.bla}
</f:for>
</div>
模板中什么也没有( DCE定义的第2个选项卡)。
https://stackoverflow.com/questions/45769329
复制相似问题