drf-分页器 响应器 url控制器 解析器

一、分页器

1、简单分页(查看第n页,每页显示m条):

使用方法:

  a、导入PageNumberPagination类;

  b、实例化产生一个对象;

  c、需要配置四个参数:page_size(必须指定,可以直接赋值或者在setting中指定),page_query_param,page_size_qury_param,max_page_size;

  d、调用paginate_queryset(list,request,self)方法,获取页面中显示的数据;

  e、序列化上个步骤中返回的数据。

 属性介绍:

  a、page_size:控制每页的显示条数;

  b、page_query_param:控制查询第几页的查询参数;

  c、page_size_qury_param:控制每页的最大显示条数;

  d、max_page_size:控制每页最大的显示条数,先满足他后,才去满足page_size_qury_param。

---- 示例:

简单分页器视图代码:

from rest_framework.pagination import PageNumberPagination
# 一 基本使用:url=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)
# 二 自定制 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)
View Code

settings

REST_FRAMEWORK = {
    # 每页显示两条
    'PAGE_SIZE':2
}
View Code

路由:

url(r'^pager/$', views.Pager.as_view()),
View Code

序列化:

class BookSerializer1(serializers.ModelSerializer):
    class Meta:
        model=models.Book
        # fields="__all__"
        exclude=('authors',)
View Code

2、偏移分页(在第n个位置,向后查看m条数据)

使用方法同简单分页

需要设置的属性:

  a、default limit:默认每页显示的条数,默认偏移的数量;

  b、limit_query_param:往后偏移多少条;

  c、offset_query_param:标杆值  用默认值offset;

  limit_query_param+offset_query_param联合起来用: 例子:访问:http://127.0.0.1:8000/books/?limit=1&offset=5  表示:以数据的第5条作为标杆,往后偏移1条

  d、max_limit:最大偏移的条数(最大取出的条数)。

# 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)
View Code

3、CursorPagination(加密分页,只能查看上一页和下一页,速度快)

属性介绍:

  a、page_size:每页显示的条数

  b、cursor_query_param:不需要变动

  c、ordering:排序方式

  通过get_paginated_response返回结果中带上一页和下一页的链接地址

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)
View Code

二、响应器

根据用户的url请求或用户可接受的类型,筛选出合适的渲染组件,即给用户返回不同数据类型的数据。

rest_framework的几种内置渲染器:

  1、显示json格式:JSONRenderer

  2、默认显示格式:BrowsableAPIRenderer(可以修改它的html文件)

  3、表格方式:AdminRenderer

  4、form表单方式:HTMLFormRenderer

局部使用:

from rest_framework.renderers import  HTMLFormRenderer,BrowsableAPIRenderer
class BookDetailView(APIView):
    renderer_classes = [HTMLFormRenderer,BrowsableAPIRenderer ]
    def get(self,request,pk):
        book_obj=models.Book.objects.filter(pk=pk).first()
        bs=BookSerializers(book_obj,many=False)
        return Response(bs.data)
    def put(self,request,pk):
        book_obj = models.Book.objects.filter(pk=pk).first()

        bs=BookSerializers(data=request.data,instance=book_obj)
        if bs.is_valid():
            bs.save() # update
            return Response(bs.data)
        else:
            return Response(bs.errors)
    def delete(self,request,pk):
        models.Book.objects.filter(pk=pk).delete()

        return Response("")
View Code

全局使用秩序要在settings中配置好即可

REST_FRAMEWORK = {
    'DEFAULT_RENDERER_CLASSES':['rest_framework.renderers.JSONRenderer']
}
View Code

自定义显示模板

from rest_framework.renderers import  TemplateHTMLRenderer
class BookDetailView(APIView):
    renderer_classes = [TemplateHTMLRenderer]
    def get(self,request,pk):
        book_obj=models.Book.objects.filter(pk=pk).first()
        bs=BookSerializers(book_obj,many=False)
        return Response(bs.data,template_name='aa.html')


----aa.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
{{ title }}
{{ publishDate }}
</body>
</html>
View Code

三、url控制器

1、自定义路由:

from django.conf.urls import url
from app01 import views
urlpatterns = [
    url(r'^books/$', views.BookView.as_view()),
    url(r'^books/(?P<pk>d+)$', views.BookDetailView.as_view()),
]
View Code

2、半自定义路由:

from django.conf.urls import url
from app01 import views
urlpatterns = [
    url(r'^publish/$', views.PublishView.as_view({'get':'list','post':'create'})),
    url(r'^publish/(?P<pk>d+)/$', views.PublishView.as_view({'get':'retrieve','put':'update','delete':'destroy'})),

]
View Code

3、自动生成路由:

from django.conf.urls import url,include
from app01 import views
from rest_framework import routers
router=routers.DefaultRouter()
# 两个参数,一个是匹配的路由,一个是视图中写的CBV的类
router.register('publish',views.PublishView)
urlpatterns = [
    # http://127.0.0.1:8000/publish/format=json(渲染器通过这个判断,返回渲染的页面)
    # url(r'^publish/', views.PublishView.as_view({'get':'list','post':'create'})),
    # http://127.0.0.1:8000/publish.json(渲染器通过这个判断,返回渲染的页面)
    # url(r'^publish.(?P<format>w+)$', views.PublishView.as_view({'get':'list','post':'create'})),
    
    # 可以用 以下方式访问
    # 1 http://127.0.0.1:8000/publish/
    # 2 http://127.0.0.1:8000/publish.json
    # 3 http://127.0.0.1:8000/publish/3
    # 4 http://127.0.0.1:8000/publish/3.json   
    url(r'',include(router.urls))
]


# 视图类
from rest_framework.viewsets import ModelViewSet
class PublishView(ModelViewSet):
    queryset=models.Publish.objects.all()
    serializer_class=PublishSerializers
View Code

四、解析器

解析器的作用:解析器是用来解析前端传递的不同数据格式的数据:urlencode,formdata,json等

默认情况下解析所有格式,内置配置了三种解析器

1、JSONParser:解析json格式的数据;

2、FormParser:解析formdata格式数据;

3、MultiPartParse:解析urlencode格式数据。

解析器的局部使用:直接在视图类中配置parser_classes=[JSONParser]

全局使用:在settings中配置:

'DEFAULT_PARSER_CLASSES': (
                'rest_framework.parsers.JSONParser',
                'rest_framework.parsers.FormParser',
                'rest_framework.parsers.MultiPartParser'
            )
View Code
原文地址:https://www.cnblogs.com/peng-zhao/p/10638097.html