【发布时间】:2019-06-04 11:08:27
【问题描述】:
我正在尝试详细说明一种在分页模板和非分页模板之间切换的智能方法。
我已经有一个工作的分页器,我正在考虑在它旁边添加一个按钮,上面写着“显示所有结果”,它链接到一个非分页列表,然后会有另一个按钮返回到分页列表。
1) 简单的解决方案
使用 2 个具有不同属性分配的 ListViews paginate_by (django 默认设置分页),但由于我的项目中有很多列表,所以不太方便(也不太聪明)。
2) 我卡住的解决方案
编写一个 Mixin(稍后将由我的 ListViews 扩展)以根据条件设置变量 paginate_by,然后将一些有用的变量添加到上下文中:
class PaginationMixin:
no_pagination = False
no_pagination_url = ''
def get_paginate_by(self, queryset):
# overwrite django method
if self.no_pagination:
return None
else:
return super().get_paginate_by(queryset)
def get_no_pagination_url(self):
return self.no_pagination_url
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
context['no_pagination'] = self.no_pagination
context['no_pagination_url'] = self.get_no_pagination_url()
return context
class MyListView(PaginationMixin, ListView):
#...
def get_no_pagination_url(self):
return reverse('mylist_urlname')
问题:我不知道如何从模板中设置 no_pagination 变量。有没有办法做到这一点?
感谢您的帮助。
更新的解决方案(编辑自@hi-lan 解决方案): 这样,它将显示所有结果并保留 urlparams(来自过滤器或其他)(如果存在)。
class PaginationMixin:
toggle_pagination = False
toggle_pagination_url = ''
no_pagination = False
view_name = ''
urlparams_dict = {}
def get(self, request, page=None, *args, **kwargs):
#store current GET params and pop 'page' key
self.urlparams_dict = request.GET
self.urlparams_dict.pop('page', None)
page = page or request.GET.get('page', '1')
if page == 'all':
page = self.paginate_by = None
self.no_pagination = True
return super().get(request, page=page, *args, **kwargs)
def get_paginate_by(self, queryset):
if self.no_pagination:
return None
else:
return super().get_paginate_by(queryset)
def get_toggle_pagination_url(self):
# variables to set in view to toggle this mixin
if self.toggle_pagination and self.view_name:
if not self.no_pagination:
extra = {'page': 'all'}
self.urlparams_dict.update(extra)
else:
self.urlparams_dict.pop('page', None)
# url keeps track of urlparams adds page=all if toggled
self.toggle_pagination_url = reverse(self.view_name) + '?' + urlencode(self.urlparams_dict)
return self.toggle_pagination_url
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
context['toggle_pagination_url'] = self.get_toggle_pagination_url()
context['toggle_pagination'] = self.toggle_pagination
return context
【问题讨论】:
标签: python django pagination