版本控制 渲染器 分页器

版本控制

版本控制:
方法一
	1 127.0.0.1/course/?version=v100000
	  from rest_framework.versioning import QueryParameterVersioning
	  在视图类里:
		versioning_class=QueryParameterVersioning(**不再是列表)
	  在setting里配置:
		REST_FRAMEWORK={
			'VERSION_PARAM':'version',
			'DEFAULT_VERSION':'v2',
			'ALLOWED_VERSIONS':['v1','v2']
		}
	取:
		视图类里:
		request.version
方法二
	127.0.0.1/v1/course/
		from rest_framework.versioning import URLPathVersioning
		在视图类里:
		versioning_class=URLPathVersioning**不再是列表)
		在setting里配置:
		REST_FRAMEWORK={
			'VERSION_PARAM':'version',
			'DEFAULT_VERSION':'v2',
			'ALLOWED_VERSIONS':['v1','v2']
		}
	取:
		视图类里:
			request.version

内置渲染器

from rest_framework.renderers import 
显示json格式:JSONRenderer

访问URL
http://127.0.0.1:8000/test/?format=json
http://127.0.0.1:8000/test.json
http://127.0.0.1:8000/test/
 
默认显示格式:BrowsableAPIRenderer(可以修改它的html文件)

访问URL
http://127.0.0.1:8000/test/?format=api
http://127.0.0.1:8000/test.api
http://127.0.0.1:8000/test/
 

表格方式:AdminRenderer

访问URL
http://127.0.0.1:8000/test/?format=admin
http://127.0.0.1:8000/test.admin
http://127.0.0.1:8000/test/
 

form表单方式:HTMLFormRenderer

访问URL
http://127.0.0.1:8000/test/?format=form
http://127.0.0.1:8000/test.form
http://127.0.0.1:8000/test/

分页器

简单分页

from rest_framework import serializers
Serializers
class BookSerializer1(serializers.ModelSerializer):
    class Meta:
        model=models.Book
        # fields="__all__"
        exclude=('authors',)
        
        
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,无效,最多5class 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)

偏移分页

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

加密分页,只能看上一页和下一页,速度快

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)
posted @ 2018-10-23 21:30  luck_L  阅读(229)  评论(0编辑  收藏  举报