6

我正在使用 knp 分页器,它运行良好,但是当我想使用它的排序功能时,我无法在 twig 中获取排序方向。

以下代码指示如何获取已排序的表头,但不考虑如何获取已排序的表头方向。

{# total items count #}
<div class="count">
    {{ pagination.getTotalItemCount }}
</div>
<table>
<tr>
{# sorting of properties based on query components #}
    <th>{{ knp_pagination_sortable(pagination, 'Id', 'a.id') }}</th>
    <th{% if pagination.isSorted('a.Title') %} class="sorted"{% endif %}>{{ knp_pagination_sortable(pagination, 'Title', 'a.title') }}</th>
</tr>

{# table body #}
{% for article in pagination %}
<tr {% if loop.index is odd %}class="color"{% endif %}>
    <td>{{ article.id }}</td>
    <td>{{ article.title }}</td>
</tr>
{% endfor %}
</table>
{# display navigation #}
<div class="navigation">
    {{ knp_pagination_render(pagination) }}
</div>

我从以下链接的 KnpPaginator 文档中获取此代码: https ://github.com/KnpLabs/KnpPaginatorBundle

4

2 回答 2

9

你应该能够{{ pagination.getDirection() }}在你的树枝模板中使用来找到当前的排序方向(如果有的话),然后根据它设置你的类。

{% set direction = pagination.getDirection() %}
<th{% if pagination.isSorted('p.id') %} class="sorted {{ direction }}"{% endif %}>
    {{ knp_pagination_sortable(pagination, 'Id', 'p.id') }}
</th>

但是......截至这篇文章,KNP 尚未合并此修复: https ://github.com/sroze/KnpPaginatorBundle/commit/3105a38714c6f89c590e49e9c50475f7a777009d

当没有设置方向参数时,当前的 Paginator bundle 会抛出错误。

因此,在合并上述修复之前,您仍然可以更详细地了解方向:

{% set directionParam = pagination.getPaginatorOption('sortDirectionParameterName') %}
{% set params = pagination.getParams() %}
{% set direction = params[directionParam] is defined ? params[directionParam] : null %}
<th{% if pagination.isSorted('p.id') %} class="sorted {{ direction }}"{% endif %}>
    {{ knp_pagination_sortable(pagination, 'Id', 'p.id') }}
</th>
于 2014-04-11T18:49:16.233 回答
4

当您调用 时{{ knp_pagination_sortable(pagination, 'Id', 'a.id') }},bundle 会自动生成一个包含有关排序方向信息的类的链接,看起来像这样:<a translationcount="" class="asc" href="?sort=a.id&direction=desc&page=1" title="Id">Id</a>所以只需将这个类放在您的 css 文件中并用箭头设置它的样式。如果您出于某种原因需要在控制器中获取排序方向,只需从 request 中读取即可$request->query->get('direction')

于 2013-11-20T08:38:27.020 回答