extbase扩展中的相同模型、不同模板(和操作)



我不知道我的扩展设置是否有点古怪。

我有一个模型,但有两个插件,因为我想用不同的方式显示相同的数据。

我想做的是:为pi1和pi2分配两个不同的Fluid模板,在那里完成所有的显示逻辑。但据我现在所知,由于"约定高于配置",我需要一个单独的pi2控制器,对吧?

现在我在ext_tables.hp:中有了这个

TYPO3CMSExtbaseUtilityExtensionUtility::configurePlugin(
    'STUBR.' . $_EXTKEY,
    'Pi1',
    array(
        'Institution' => 'list, show',
    ),
    // non-cacheable actions
    array(
        'Institution' => '',
    )
);
TYPO3CMSExtbaseUtilityExtensionUtility::configurePlugin(
    'STUBR.' . $_EXTKEY,
    'Pi2',
    array(
        'Institution' => 'list, show',
    ),
    // non-cacheable actions
    array(
        'Institution' => '',
    )
);

我真的必须通过在控制器和模板目录中重新命名"机构"来调整一切吗?

要回答您在回答中提出的问题。。。可以在每个插件的基础上配置扩展的TypoScript。只需将带有前导下划线的插件名称添加到您的TS密钥中,如所示

plugin.tx_stellen_pi2 {
    settings {
       displaymode = 1
    }
}

不使用if条件,您还可以设置不同的TemplateRootPath,以便为pi2呈现另一个模板。

请记住,您可以在FlexForm中设置displayMode。前缀为settings.的每个FlexForm属性都将在{settings}数组中可用。只需在ext_tables.php:中配置FlexForm
$pluginSignature = str_replace('_','',$_EXTKEY) . '_pi1';
$GLOBALS['TCA']['tt_content']['types']['list']['subtypes_addlist'][$pluginSignature] = 'pi_flexform';
TYPO3CMSCoreUtilityExtensionManagementUtility::addPiFlexFormValue($pluginSignature, 'FILE:EXT:' . $_EXTKEY . '/Configuration/FlexForm/flexform_pi1.xml');

然后将FlexForm XML添加到配置的路径:

<T3DataStructure>
    <meta>
        <langDisable>1</langDisable>
    </meta>
    <sheets>
        <sDEF>
            <ROOT>
                <TCEforms>
                    <sheetTitle>Configuration</sheetTitle>
                </TCEforms>
                <type>array</type>
                <el>
                    <settings.displayMode>
                        <TCEforms>
                            <exclude>0</exclude>
                            <label>Display mode</label>
                            <config>
                                <type>select</type>
                                <items type="array">
                                    <numIndex index="0" type="array">
                                        <numIndex index="0">Neat</numIndex>
                                        <numIndex index="1">1</numIndex>
                                    </numIndex>
                                    <numIndex index="1" type="array">
                                        <numIndex index="0">Clean</numIndex>
                                        <numIndex index="1">2</numIndex>
                                    </numIndex>
                                </items>
                                <minitems>0</minitems>
                                <maxitems>1</maxitems>
                                <size>1</size>
                            </config>
                        </TCEforms>
                    </settings.displayMode>
                </el>
            </ROOT>
        </sDEF>
    </sheets>
</T3DataStructure>

在本例中,添加了一个选择框,其中包含两个选项"neat"one_answers"clean"。

然后,您可以在Fluid模板中使用它(如果您有两种以上的模式,也可以使用SwitchViewHelper而不是if构造):

<f:if condition="{settings.displayMode} == 1">
    <f:then>
        <f:render partial="Neat/List" arguments="{_all}" />
    </f:then>
    <f:else>
        <f:render partial="Clean/List" arguments="{_all}" />
    </f:else
</f:if>

记住,你可以嵌套分部,所以在分部中有分部是没有问题的。因此,只需对每个视图使用分部。

如果你想让它看起来不那么粗糙,你可以给显示模式一个说话的值:

<numIndex index="0" type="array">
    <numIndex index="0">Neat</numIndex>
    <numIndex index="1">Neat</numIndex>
</numIndex>
<numIndex index="1" type="array">
    <numIndex index="0">Clean</numIndex>
    <numIndex index="1">Clean</numIndex>
</numIndex>

然后你可以用它来调用像这样的部分

<f:render partial="List/{settings.displayMode}" arguments="{_all}" />

并以这种方式去掉if构造。

我现在是这样做的。保留一个控制器,只需在插件所在的页面上设置一些页面TS即可分叉模板。

plugin.tx_stellen {
    settings {
       displaymode = 1
    }
}

然后<f:if condition="{settings.displaymode}==1"></f:if>

不过,这是一种变通方法,因为它对整个页面都有效(我甚至根本不需要这三个不同的插件)。难道不能直接在扩展中定义TypoScript"每个插件"吗?

最新更新