django forloop 计数器在新页面中重新启动
django foorloop counter restarts in a new page
目前我正在用 django 编写一个简单的待办事项列表。我有一个视图和 html 文件用于显示项目列表,我希望 table 中的每个任务都有一个编号,从 1 开始。我在我的文件中使用 {% footloop.counter %}
模板。
在我编写分页器之前一切正常。当您选择进入下一页时,计数器又从1开始,因此每页的table中的数字也从1开始。但我希望数字按顺序继续到最后一页。是否有任何模板标签或代码片段?
提前致谢。
这里是涉及的代码:
**list.html:**
{% for task in tasks %}
<tbody>
<tr>
<th scope="row" class="col-md-1">{{ forloop.counter }}</th>
<td class="col-md-2">{{ task.title }}</td>
<td class="col-md-3">{{ task.description|truncatewords:10 }}</td>
<td class="col-md-2">{{ task.time|date:"H:i" }} - {{ task.time|date:"D d M , Y" }}</td>
</tr>
</tbody>
{% endfor %}
<!--Pagination-->
{% if is_paginated %}
<div class="container p-4">
<div class="pagination justify-content-center">
<span class="step-links">
{% if page_obj.has_previous %}
<a href="{% url 'home:list' 1 %}">« first</a>
<a href="{% url 'home:list' page_obj.previous_page_number %}">previous</a>
{% endif %}
<span class="current">
Page {{ page_obj.number }} of {{page_obj.paginator.num_pages }}
</span>
{% if page_obj.has_next %}
<a href="{% url 'home:list' page_obj.next_page_number %}">next</a>
<a href="{% url 'home:list' page_obj.paginator.num_pages%}">last »</a>
{% endif %}
</span>
</div>
</div>
{% endif %}
您可以尝试构建自己的模板标签并在模板上使用它,如下所示:-
@register.filter
def adjust_for_counter(value, page):
value, page = int(value), int(page)
counter_value = value + ((page - 1) * settings.RESULTS_PER_PAGE)
return counter_value
并在 html 中像下面这样称呼它:-
{{ forloop.counter|adjust_for_pagination:page }}
详情请参考以下内容link :-
https://djangosnippets.org/snippets/1391/
目前我正在用 django 编写一个简单的待办事项列表。我有一个视图和 html 文件用于显示项目列表,我希望 table 中的每个任务都有一个编号,从 1 开始。我在我的文件中使用 {% footloop.counter %}
模板。
在我编写分页器之前一切正常。当您选择进入下一页时,计数器又从1开始,因此每页的table中的数字也从1开始。但我希望数字按顺序继续到最后一页。是否有任何模板标签或代码片段? 提前致谢。
这里是涉及的代码:
**list.html:**
{% for task in tasks %}
<tbody>
<tr>
<th scope="row" class="col-md-1">{{ forloop.counter }}</th>
<td class="col-md-2">{{ task.title }}</td>
<td class="col-md-3">{{ task.description|truncatewords:10 }}</td>
<td class="col-md-2">{{ task.time|date:"H:i" }} - {{ task.time|date:"D d M , Y" }}</td>
</tr>
</tbody>
{% endfor %}
<!--Pagination-->
{% if is_paginated %}
<div class="container p-4">
<div class="pagination justify-content-center">
<span class="step-links">
{% if page_obj.has_previous %}
<a href="{% url 'home:list' 1 %}">« first</a>
<a href="{% url 'home:list' page_obj.previous_page_number %}">previous</a>
{% endif %}
<span class="current">
Page {{ page_obj.number }} of {{page_obj.paginator.num_pages }}
</span>
{% if page_obj.has_next %}
<a href="{% url 'home:list' page_obj.next_page_number %}">next</a>
<a href="{% url 'home:list' page_obj.paginator.num_pages%}">last »</a>
{% endif %}
</span>
</div>
</div>
{% endif %}
您可以尝试构建自己的模板标签并在模板上使用它,如下所示:-
@register.filter
def adjust_for_counter(value, page):
value, page = int(value), int(page)
counter_value = value + ((page - 1) * settings.RESULTS_PER_PAGE)
return counter_value
并在 html 中像下面这样称呼它:-
{{ forloop.counter|adjust_for_pagination:page }}
详情请参考以下内容link :- https://djangosnippets.org/snippets/1391/