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

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

此文件包含用于显示数据列表经常使用的类和工具类。不只能够方便的用于显示基于模型(Model)的数据列表,也能够用于显示自定义数据列表。html

list.py类图

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

MultipleObjectMixin

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

  • 属性

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

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

model 关联的模型类。设计

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

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属性,指定每页数据项数目。

相关文章
相关标签/搜索