Django框架中的对象列表视图使用示例
2015-07-21 15:18
886 查看
direct_to_template 毫无疑问是非常有用的,但Django通用视图最有用的地方是呈现数据库中的数据。 因为这个应用实在太普遍了,Django带有很多内建的通用视图来帮助你很容易 地生成对象的列表和明细视图。
让我们先看看其中的一个通用视图: 对象列表视图。 我们使用第五章中的 Publisher 来举例:
class Publisher(models.Model): name = models.CharField(max_length=30) address = models.CharField(max_length=50) city = models.CharField(max_length=60) state_province = models.CharField(max_length=30) country = models.CharField(max_length=50) website = models.URLField() def __unicode__(self): return self.name class Meta: ordering = ['name']
要为所有的出版商创建一个列表页面,我们使用下面的URL配置:
from django.conf.urls.defaults import * from django.views.generic import list_detail from mysite.books.models import Publisher publisher_info = { 'queryset': Publisher.objects.all(), } urlpatterns = patterns('', (r'^publishers/$', list_detail.object_list, publisher_info) )
这就是所要编写的所有Python代码。 当然,我们还需要编写一个模板。 我们可以通过在额外参数字典中包含一个template_name键来显式地告诉object_list视图使用哪个模板:
from django.conf.urls.defaults import * from django.views.generic import list_detail from mysite.books.models import Publisher publisher_info = { 'queryset': Publisher.objects.all(), **'template_name': 'publisher_list_page.html',** } urlpatterns = patterns('', (r'^publishers/$', list_detail.object_list, publisher_info) )
在缺少template_name的情况下,object_list通用视图将自动使用一个对象名称。 在这个例子中,这个推导出的模板名称将是 "books/publisher_list.html" ,其中books部分是定义这个模型的app的名称, publisher部分是这个模型名称的小写。
这个模板将按照 context 中包含的变量 object_list 来渲染,这个变量包含所有的书籍对象。 一个非常简单的模板看起来象下面这样:
{% extends "base.html" %} {% block content %} <h2>Publishers</h2> <ul> {% for publisher in object_list %} <li>{{ publisher.name }}</li> {% endfor %} </ul> {% endblock %}
(注意,这里我们假定存在一个base.html模板。)
这就是所有要做的事。 要使用通用视图酷酷的特性只需要修改参数字典并传递给通用视图函数。 附录D是通用视图的完全参考资料;本章接下来的章节将讲到自定义和扩展通用视图的一些方法。
您可能感兴趣的文章:
相关文章推荐
- 动态生成SQL Server视图作业
- SQL server 视图(view)介绍
- dba_indexes视图的性能分析
- SQL SERVER先判断视图是否存在然后再创建视图的语句
- sql server判断数据库、表、列、视图是否存在
- ASP.NET Web API教程 创建Admin视图详细介绍
- SQLite教程(三):数据表和视图简介
- oracle中的视图详解
- windows+apache+mod_python配置django运行环境
- python Django连接MySQL数据库做增删改查
- django自定义Field实现一个字段存储以逗号分隔的字符串
- 简介AngularJS的视图功能应用
- ASP.NET MVC中的视图生成实例分析
- 跟我学Laravel之视图 & Response
- Laravel 5框架学习之向视图传送数据
- 解析SQL Server 视图、数据库快照
- MySQL笔记之视图的使用详解
- 基于mysql事务、视图、存储过程、触发器的应用分析
- android开发教程之使用线程实现视图平滑滚动示例
- 在Python的Django框架中加载模版的方法