# 普通分页
from rest_framework.pagination import PageNumberPagination
# from rest_framework.versioning import URLPathVersioning
# class Book(ViewSetMixin, APIView):
#版本控制局部使用
# versioning_class = URLPathVersioning
# def get_all(self, request,*args,**kwargs):
# 提供给咱的解析
# url2=request.versioning_scheme.reverse('ttt',request=request)
# print(url2)#获取到带有版本号的ip地址
# response = {'status': 100, 'msg': '查询成功'}
# book_list = models.Book.objects.all()
# # 实例化产生一个分页对象
# # 不继承来修改对象的值
# page=PageNumberPagination()
# # 每页显示多少条
# page_size = 3
# # 查询的key,问号后面的key
# page_query_param = 'aa'
# # 指定当前页显示多少条
# page_size_query_param='size'
# # 每页最多显示多少条
# max_page_size=4
# # 第一个参数:要分页的数据,第二个参数request对象,第三个参数,当前视图对象
# page_list = page.paginate_queryset(book_list, request, self)
# # 再序列化的时候,用分页之后的数据
# ser = mySer.BookSerializer(instance=page_list, many=True)
# # response['data'] = ser.data
# # return Response(response)
# # 会带着链接,和总共的条数(不建议用)
# return page.get_paginated_response(ser.data)
# # return Response(ser.data)
路由----------------------------------------------------------------------------------------------------
#版本控制路由
# url(r'^(?P[v1|v2|v3]+)/books/$', views.Book.as_view({'get': 'get_all'}), name='ttt'),
在setting中---------------------------------------------------------------------------------------------
REST_FRAMEWORK = {
# 'DEFAULT_VERSIONING_CLASS':'rest_framework.versioning.URLPathVersioning',#版本控制全局使用
# 'VERSION_PARAM': 'version',
# 'DEFAULT_VERSION': 'v1',
# 'ALLOWED_VERSIONS': ['v1', 'v2'],
}
文章题目:rest_framework分页,版本控制
URL地址:
http://njwzjz.com/article/ipcpdg.html