TYPO3新闻 - 定义自己的模板

时间:2017-03-13 14:22:51

标签: typo3 typo3-7.6.x tx-news typo3-extensions

我正在使用带有新闻扩展的TYPO3 7.6.14。我想在后端的不同视图之间切换。

根目录中的页面TS:

tx_news.templateLayouts {     
 Custom = Gesamter Artikel2
}

enter image description here

<html xmlns:f="http://typo3.org/ns/TYPO3/CMS/Fluid/ViewHelpers"
      xmlns:n="http://typo3.org/ns/GeorgRinger/News/ViewHelpers"
      data-namespace-typo3-fluid="true">
<f:layout name="General" />
<!--
    =====================
        Templates/News/List.html
-->

<f:section name="content">
    <!--TYPO3SEARCH_end-->
    <f:if condition="{news}">
        <f:then>
            <div class="news-list-view">
                <f:if condition="{settings.hidePagination}">
                    <f:then>
                        <f:for each="{news}" as="newsItem">
                            <f:if condition="{0:settings.templateLayout} == {0:'Custom}">
                                <f:then>
                                    <f:render partial="List/GesamteArtikel" arguments="{newsItem: newsItem, settings:settings, className:className, view:'list'}"/>
                                </f:then>
                                <f:else>
                                    <f:render partial="List/Item" arguments="{newsItem: newsItem, settings:settings, className:className, view:'list'}"/>
                                </f:else>
                            </f:if>
                        </f:for> 
                    </f:then>
                    <f:else>
                        <n:widget.paginate objects="{news}" as="paginatedNews" configuration="{settings.list.paginate}" initial="{offset:settings.offset,limit:settings.limit}">
                            <f:for each="{paginatedNews}" as="newsItem" iteration="iterator">
                                <f:render partial="List/Item" arguments="{newsItem: newsItem,settings:settings,iterator:iterator}" />
                            </f:for>
                        </n:widget.paginate>
                    </f:else>
                </f:if>
            </div>
        </f:then>
        <f:else>
            <div class="no-news-found">
                <f:translate key="list_nonewsfound" />
            </div>
        </f:else>
    </f:if>
    <!--TYPO3SEARCH_begin-->
</f:section>
</html>

在我拥有List.html的同一文件夹中,我添加了自己的文件名为GesamteArtikel.html

我做错了什么?

编辑:

(更改文件的位置)

我发现它没有任何影响。我将其更改为:

            <f:then>
                <f:for each="{news}" as="newsItem">
                    <f:if condition="{settings.templateLayout} == 'Custom'">
                        <f:then>
                            <f:render partial="GesamteArtikel" arguments="{newsItem: newsItem, settings:settings, className:className, view:'list'}"/>
                        </f:then>
                        <f:else>
                            <f:render partial="GesamteArtikel" arguments="{newsItem: newsItem, settings:settings, className:className, view:'list'}"/>
                        </f:else>
                    </f:if>
                </f:for> 
            </f:then>

它没有做任何事。

使用

            <f:else>
                <n:widget.paginate objects="{news}" as="paginatedNews" configuration="{settings.list.paginate}" initial="{offset:settings.offset,limit:settings.limit}">
                    <f:for each="{paginatedNews}" as="newsItem" iteration="iterator">
                        <f:render partial="List/Item" arguments="{newsItem: newsItem,settings:settings,iterator:iterator}" />
                    </f:for>
                </n:widget.paginate>
            </f:else>
然后我将其改为

            <f:else>
                <n:widget.paginate objects="{news}" as="paginatedNews" configuration="{settings.list.paginate}" initial="{offset:settings.offset,limit:settings.limit}">
                    <f:for each="{paginatedNews}" as="newsItem" iteration="iterator">
                        <f:if condition="{settings.templateLayout} == 'Layout'">
                            <f:then>
                                <f:render partial="GesamteArtikel" arguments="{newsItem: newsItem, settings:settings, className:className, view:'list'}"/>
                            </f:then>
                            <f:else>
                                <f:render partial="List/Item" arguments="{newsItem: newsItem, settings:settings, className:className, view:'list'}"/>
                            </f:else>
                        </f:if>
                    </f:for>
                </n:widget.paginate>
            </f:else>

但它只使用Item.html 如果我告诉两个语句是否使用GesamteArtikel(自定义模板)它将使用它,但我不想覆盖旧的item.html。我想在后端选择它时使用我的自定义布局......

1 个答案:

答案 0 :(得分:0)

有两件事可能会有所帮助:

首先,您的比较中似乎缺少单引号:

  

<f:if condition="{0:settings.templateLayout} == {0:'Custom}">

你可以在没有数组旁路的情况下进行字符串比较,所以得到的是:

<f:if condition="{settings.templateLayout} == 'Custom'">

第二件事是自定义布局文件的位置:

  

在我拥有List.html的同一文件夹中,我添加了自己的文件名为GesamteArtikel.html

您需要将其放在部分根路径中的某个位置,例如部分EXT:my_ext/Resources/Private/Partials/List/的{​​{1}}兄弟(如果您覆盖该部分的话)。