使用带有 rest 框架的 Django 分页转到特定页面
Go to specific page using Django Pagination with restframework
我有一个关于在 Django restframework 中使用分页转到特定页面的问题。
(数据需要渲染到HTML)
示例:
model.py
class Book(models.Model):
title = models.CharField(max_length=30)
author = models.CharField(max_length=30)
views.py
class BookListView(viewsets.ModelViewSet):
permission_classes = (AllowAny, )
template_name = 'booklist.html'
queryset = Book.objects.all()
renderer_classes = [TemplateHTMLRenderer]
pagination_class = BookPagination
serializer_class = BookSerializer
def list(self, request):
queryset = Book.objects.all()
serializer = ProtocolSerializer(queryset, many=True)
page = self.paginate_queryset(serializer.data)
return self.get_paginated_response(page)
我可以用上面的代码显示分页项目。
HTML 中有下一个和上一个链接。
但是,我需要像 [1,2,3,....] 这样的页面列表,而不仅仅是下一个和上一个。
只需单击按钮 3,我就可以在第 3 页上查看数据。
我需要一些步骤来执行此操作。
1:检索目标页码(我不知道该怎么做)
2:获取该页的数据
3:渲染到 HTML
我希望有人能帮助我。
您可以创建自己的分页器,方法是继承 PageNumberPagination
以将所有可用页面的列表添加到响应中:
class AllPageNumberPagination(PageNumberPagination):
def get_paginated_response(self, data):
return Response(OrderedDict([
('count', self.page.paginator.count),
('next', self.get_next_link()),
('pages', self.get_all_pages_links()),
('previous', self.get_previous_link()),
('results', data)
]))
def get_all_pages_links(self):
base_url = self.request.build_absolute_uri()
def page_number_to_url(page_number):
if page_number == 1:
return remove_query_param(base_url, self.page_query_param)
else:
return replace_query_param(base_url, self.page_query_param, page_number)
page_numbers = range(1, self.page.paginator.num_pages + 1)
page_links = []
for page_number in page_numbers:
page_links.append(page_number_to_url(page_number))
return page_links
我有一个关于在 Django restframework 中使用分页转到特定页面的问题。 (数据需要渲染到HTML)
示例:
model.py
class Book(models.Model):
title = models.CharField(max_length=30)
author = models.CharField(max_length=30)
views.py
class BookListView(viewsets.ModelViewSet):
permission_classes = (AllowAny, )
template_name = 'booklist.html'
queryset = Book.objects.all()
renderer_classes = [TemplateHTMLRenderer]
pagination_class = BookPagination
serializer_class = BookSerializer
def list(self, request):
queryset = Book.objects.all()
serializer = ProtocolSerializer(queryset, many=True)
page = self.paginate_queryset(serializer.data)
return self.get_paginated_response(page)
我可以用上面的代码显示分页项目。 HTML 中有下一个和上一个链接。 但是,我需要像 [1,2,3,....] 这样的页面列表,而不仅仅是下一个和上一个。 只需单击按钮 3,我就可以在第 3 页上查看数据。 我需要一些步骤来执行此操作。
1:检索目标页码(我不知道该怎么做)
2:获取该页的数据
3:渲染到 HTML
我希望有人能帮助我。
您可以创建自己的分页器,方法是继承 PageNumberPagination
以将所有可用页面的列表添加到响应中:
class AllPageNumberPagination(PageNumberPagination):
def get_paginated_response(self, data):
return Response(OrderedDict([
('count', self.page.paginator.count),
('next', self.get_next_link()),
('pages', self.get_all_pages_links()),
('previous', self.get_previous_link()),
('results', data)
]))
def get_all_pages_links(self):
base_url = self.request.build_absolute_uri()
def page_number_to_url(page_number):
if page_number == 1:
return remove_query_param(base_url, self.page_query_param)
else:
return replace_query_param(base_url, self.page_query_param, page_number)
page_numbers = range(1, self.page.paginator.num_pages + 1)
page_links = []
for page_number in page_numbers:
page_links.append(page_number_to_url(page_number))
return page_links