码迷,mamicode.com
首页 > 其他好文 > 详细

Django——基于类的视图源码分析 三

时间:2014-10-20 19:08:47      阅读:215      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   os   ar   使用   strong   sp   文件   

列表类通用视图(list.py)

此文件包含用于显示数据列表常用的类和工具类。不仅可以方便的用于显示基于模型(Model)的数据列表,也可以用于显示自定义数据列表。

bubuko.com,布布扣

此图中绿色部分属于base.py,引入此图中是为了说明他们之间的关系

MultipleObjectMixin

最主要的核心工具类,主要的算法和接口全部都在这个工具类中实现。

  • 属性

allow_empty 默认值True。表示没有数据时显示空列表;否则将会产生一个404错误。

queryset 产生数据的queryset实例或"类queryset"数据列表。

model 关联的模型类。

paginated_by 分页的每页数据项数。默认不起用分页。

context_object_name 保存到context中的对象名称。默认是$(model)_list。

paginator_class 默认值Paginator。分页处理器。

  • 方法

get_queryset 获取用于数据显示的列表对象。可以是类queryset对象。此方法优先选择使用queryset属性。未提供queryset属性时,返回model的默认管理器。如果也没有提供model属性,将会产生ImproperlyConfigured异常。

paginate_queryset 根据需要,将queryset分页。返回(paginator, page, page.object_list, page.has_other_pages())

get_paginate_by 返回每页数据项数。None表示不分页。

get_paginator 返回分页器

get_allow_empty 参见allow_empty属性说明

get_context_object_name 参见context_object_name属性说明

get_context_data 设置视图的附加属性。通常重写此方法来为视图提供附加数据
默认设计的视图数据:

‘paginator‘: 分页器,
‘page_obj‘: 页对象,
‘is_paginated‘: 是否进行了分页,
‘object_list‘: 视图的数据

BaseListView

视图列表基类。继承自MutipleObjectMixin和View。这是一个抽象类。此函数通过增加get方法来整合View的处理流程和MutipleObjectMixin提供的工具函数。

MultipleObjectTemplateResponseMixin

继承自TemplateResponseMixin,并重写get_template_names方法。追加$(app_label)/$(model)_list.html作为默认模板。

ListView

本模块功能集大成者。一般都是直接继承此类,并重写MutipleObjectMixin的一些默认属性和/或方法来实现需求。

此类继承自MultipleObjectTemplateResponseMixin和BaseListView。一般来说,只需提供model属 性,并编写$(model)_list.html即可实现数据列表功能。如需分页可以重写paginated_by属性,指定每页数据项数目。

Django——基于类的视图源码分析 三

标签:style   blog   http   os   ar   使用   strong   sp   文件   

原文地址:http://www.cnblogs.com/Simon-xm/p/4038290.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!