typoscript日期是来自DB的tstamp如何格式化

时间:2013-07-08 07:21:46

标签: typo3 typoscript

我有这段代码从数据库中获取日期并在powermail中填写输入字段:

termin = TEXT
termin.stdWrap.dataWrap = DB:tx_seminars_seminars:{GP:tx_seminars_pi1|uid}:begin_date
termin.stdWrap.outerWrap = {|}
termin.insertData = 1
termin.htmlSpecialChars  = 1

字段begin_date中的值以powermail格式显示,但我需要以人类可读的格式显示它(在DB中它是unix时间) 我的问题是从%t%到%d%m%y

如何格式化?

2 个答案:

答案 0 :(得分:2)

stdWrap有一个日期属性。

#Example where a timestamp is imported:
test.value.field = tstamp
test.value.date = d.m.Y H:i:s

http://wiki.typo3.org/TSref/stdWrap#date

编辑: 请注意,TEXT stdWrap的实例。你不需要为那个简单的包装修改stdWrap。添加{}会修改timstamp,以便日期无法获得正确的值。

答案 1 :(得分:0)

这是添加日期的最佳解决方案,就像以前的格式一样:

渲染流体部分,如下所示:

<f:render section="timeAgo" arguments="{posted:'{posting.datePosted}'}" />

流体部分:

<f:section name="timeAgo">
    <f:variable name="now" value="{f:format.date(date: 'now',format:'%s')}" />
    <f:variable name="posted" value="{f:format.date(date:'{posted}',format:'%s')}" />
    <f:variable name="diff" value="{now - posted}" />
    <f:if condition="{diff} < 60">
        <f:then>Now</f:then>
        <f:else if="{diff} < 3600">
            <f:format.number decimals="0">{diff / 60}</f:format.number> minute ago
        </f:else>
        <f:else if="{diff} < 86400">
            <f:format.number decimals="0">{diff / 3600}</f:format.number> hours ago
        </f:else>
        <f:else if="{diff} < 604800">
            <f:format.number decimals="0">{diff / 86400}</f:format.number> days ago
        </f:else>
        <f:else if="{diff} < 2419200">
            <f:format.number decimals="0">{diff / 604800}</f:format.number> weeks ago
        </f:else>
        <f:else if="{diff} < 29030400">
            <f:format.number decimals="0">{diff / 2419200}</f:format.number> months ago
        </f:else>
        <f:else>{f:format.date(date: '{posted}',format:'%d %B, %Y')}</f:else>
    </f:if>
</f:section>

只需在参数=“ {posted:'{posting.datePosted}'}”处传递正确的变量对象即可。

谢谢!