第九章 restframework——分页器
一、简单分页(常用)
二、偏移分页(不常用)
三、加密分页(效率高,且安全)
一、简单分页(常用)
需求:查看第n页,每页显示n条
urls.py
url(r'^pager/$', views.Pager.as_view()),
Serializers
class BookSerializer1(serializers.ModelSerializer): class Meta: model=models.Book # fields="__all__" exclude=('authors',)
导入模块
from rest_framework.pagination import PageNumberPagination
settings.py
REST_FRAMEWORK = { # 每页显示两条 'PAGE_SIZE':2 }
1.使用默认配置
views.py
from rest_framework.pagination import PageNumberPagination # url=http://127.0.0.1:8000/pager/?page=2&size=3,size无效 class Pager(APIView): def get(self,request,*args,**kwargs): # 获取所有数据 ret=models.Book.objects.all() # 创建分页对象 page=PageNumberPagination() # 在数据库中获取分页的数据 page_list=page.paginate_queryset(ret,request,view=self) # 对分页进行序列化 ser=BookSerializer1(instance=page_list,many=True) return Response(ser.data)
2.自定义(继承PageNumberPagination类,重写属性)
# url=http://127.0.0.1:8000/pager/?page=2&size=3 # size=30,无效,最多5条 class Mypage(PageNumberPagination): page_size = 2 page_query_param = 'page' # 定制传参 page_size_query_param = 'size' # 最大一页的数据 max_page_size = 5 class Pager(APIView): def get(self,request,*args,**kwargs): # 获取所有数据 ret=models.Book.objects.all() # 创建分页对象 page=Mypage() # 在数据库中获取分页的数据 page_list=page.paginate_queryset(ret,request,view=self) # 对分页进行序列化 ser=BookSerializer1(instance=page_list,many=True) # return Response(ser.data) # 这个也是返回Response对象,但是比基本的多了上一页,下一页,和总数据条数(了解即可) return page.get_paginated_response(ser.data)
# 1 再setting里配置每页条数 # 2 写一个类,继承它,属性重写 # 3 再对象里修改 ''' 每页显示多少条api_settings.PAGE_SIZE page_size = 查询指定页码的参数 page_query_param = 'page' 指定每页显示条数 page_size_query_param = None 限制每页显示最大条数 max_page_size = None '''
二、偏移分页(不常用)
需求:在第n个位置,向后查看n条数据
# http://127.0.0.1:8000/pager/?offset=4&limit=3 from rest_framework.pagination import LimitOffsetPagination # 也可以自定制,同简单分页 class Pager(APIView): def get(self,request,*args,**kwargs): # 获取所有数据 ret=models.Book.objects.all() # 创建分页对象 page=LimitOffsetPagination() # 在数据库中获取分页的数据 page_list=page.paginate_queryset(ret,request,view=self) # 对分页进行序列化 ser=BookSerializer1(instance=page_list,many=True) # return page.get_paginated_response(ser.data) return Response(ser.data)
# 1 再setting里配置每页条数 # 2 写一个类,继承它,属性重写 # 3 再对象里修改 ''' default_limit:默认显示多少条 max_limit:最大显示多少条 limit_query_param:重新命名limit(limit=4:表明显示四条,受max_limit的限制) offset_query_param:指定查询的标杆名(offset=1:表明从第二条开始,往后偏移) '''
三、加密分页(效率高,且安全)
需求:加密分页,只能看上一页和下一页
from rest_framework.pagination import CursorPagination # 看源码,是通过sql查询,大于id和小于id class Pager(APIView): def get(self,request,*args,**kwargs): # 获取所有数据 ret=models.Book.objects.all() # 创建分页对象 page=CursorPagination() page.ordering='nid' # 在数据库中获取分页的数据 page_list=page.paginate_queryset(ret,request,view=self) # 对分页进行序列化 ser=BookSerializer1(instance=page_list,many=True) # 可以避免页码被猜到 return page.get_paginated_response(ser.data)
# 1 再setting里配置每页条数 # 2 写一个类,继承它,属性重写 # 3 再对象里修改 ''' cursor_query_param = 'cursor':查询的名字 page_size = api_settings.PAGE_SIZE:每页显示的条数 ordering = '-created' :按谁排序 '''