• 版本控制 渲染器 分页器


    版本控制

    版本控制:
    方法一
    	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)
  • 相关阅读:
    List<Object> 查询解析优化
    hibernate 中 query.list()的优化
    移动端屏幕宽度自适应原理及实现
    js获取用户当前地理位置(省、市、经纬度)
    mescroll.js简单的上拉加载、下拉刷新插件,带完整注释
    Web前端性能优化总结——如何提高网页加载速度
    浏览器渲染页面的原理及流程
    优酷1080p的kux格式文件怎么转换为MP4格式?
    js处理文章详情页点击量统计
    plupload上传视频插件jQuery+php
  • 原文地址:https://www.cnblogs.com/luck-L/p/9839533.html
Copyright © 2020-2023  润新知