我有这段代码从数据库中获取日期并在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
如何格式化?
答案 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}'}”处传递正确的变量对象即可。
谢谢!