我需要在TWIG中填写数据库中的数据。一切都很好,除了这个:
我需要使用带有DATEDIFF属性的列来获取天数。
TODAY-dateFromDateBase
问题是: 如何在树枝中获取循环天数?
这是我的枝条:
<table>
<thead>
<tr>
<form action="" method="post" {{ form_enctype(searchform) }} class="form-index-permits">
<td>L.p </td>
<td>ID PRZEPUSTKI {{ form_widget(searchform.PermitId) }}</td>
<td>Name{{ form_widget(searchform.Permitname) }}</td>
<td>Surname {{ form_widget(searchform.Permitsurname) }}</td>
<td>Company {{ form_widget(searchform.Company) }}</td>
<td>GW {{ form_widget(searchform.Contractor) }}</td>
<td>Dayleft {{ form_widget(searchform.Dayleft) }}</td>
<td>End date {{ form_widget(searchform.date, { 'attr': {'class': 'datepicker'} }) }}</td>
</form>
</tr>
</thead>
{% for permit in permitcollection %}
<tbody>
<td>{{ loop.index }}</td>
<td>{{ permit.getPermitid()|number_format(0, '.', ' ') }}</td>
<td>{{ permit.getPermitname() }}</td>
<td>{{ permit.getPermitsurname() }}</td>
<td>{{ permit.getPermitsCompany().getName() }}</td>
<td>{{ permit.getPermitsContractor().getName() }}</td>
<td> HERE I WANT TO DISPLAY DAYS LEFT</td>
<td>{{ permit.getExpirationdate()|date('Y-m-d') }}</td>
</tbody>
{% endfor %}
</table>
这样的事情可能吗?
{{ permit.getExpirationdate()|date('Y-m-d') - "now"|date('Y-m-d') }}
答案 0 :(得分:4)
第一个解决方案(推荐)“使用现有库”:
您可以使用KnpTimeBundle
在树枝上: 这与当前日期进行比较:
{# Returns something like "3 minutes ago" #}
{{ time_diff(permit.expirationDate) }}
这与另一个日期比较:
{# Returns something like "3 minutes ago" #}
{{ time_diff(permit.expirationDate, anotherDate) }}
第二个解决方案“自己动手”:
通过php函数制作差异:
$calcFrom = permit.getExpirationdate()
$now = new \DateTime('now');
$now->diff($calcFrom)->format("%a")
并通过Twig extension或直接在实体中的辅助方法中提供。
另一种可能的解决方案是编写注册表custom DQL Function来完成存储库中的工作
希望这个帮助